前端之JavaScript:JS之DOM对象三

阅读: 评论:0

前端之JavaScript:JS之DOM对象三

前端之JavaScript:JS之DOM对象三

js之DOM对象三

一、JS中for循环遍历测试

for循环遍历有两种

第一种:是有条件的那种,例如    for(var i = 0;i<ele.length;i++){}

第二种:for (var i in li ){}

现在我们来说一下测试一下第二种(数组和obj的)

 1 <!DOCTYPE html>2 <html lang="en">3 <head>4     <meta charset="UTF-8">5     <title>Title</title>6 </head>7 <body>8 <script>9     var arr = [11,22,33,44,55];
10     var obj = {'username':'zzz','agr':20};  //js中的这个类似字典的不叫字典,而是一个对象
11     for (var i in obj){
12         console.log(i);  //拿到的是键
13         console.log(obj[i]) //值
14     }
15     for (var j in arr){
16         console.log(j); //拿到索引
17         console.log(arr[j])  //拿到值
18     }
19 </script>
20 </body>
21 </html>
测试for循环

二、获取value属性值

1 <!DOCTYPE html>2 <html lang="en">3 <head>4     <meta charset="UTF-8">5     <title>获取value值</title>6 </head>7 <body>8 <input type="text" id="c1">9 <select name="pro" id="s1">
10         <option value="1">河北省</option>
11         <option value="2">河南省</option>
12         <option value="3">北京省</option>
13 </select>
14 <button>show</button>
15 <script>
16      var ele_button&#ElementsByTagName("button")[0];
17 
18     ele_button.οnclick=function () {
19         var ele_input&#ElementById("c1");
20         var ele_select&#ElementById("s1");
21         console.log(ele_select.value)
22     };
23 </script>
24 </body>
25 </html>
View Code

三、表格示例(全选,反选,取消)

  1 <!DOCTYPE html>2 <html lang="en">3 <head>4     <meta charset="UTF-8">5     <title>表格示例</title>6 </head>7 <body>8 <button class="select">全选</button>9 <button class="reserve">反选</button>10 <button class="cancel">取消</button>11 <table border="1">12     <tr>13         <td><input type="checkbox" class="check"></td>14         <td>111</td>15         <td>222</td>16         <td>333</td>17     </tr>18      <tr>19         <td><input type="checkbox" class="check"></td>20         <td>111</td>21         <td>222</td>22          <td>333</td>23     </tr>24      <tr>25         <td><input type="checkbox" class="check"></td>26         <td>111</td>27         <td>222</td>28          <td>333</td>29     </tr>30      <tr>31         <td><input type="checkbox" class="check"></td>32         <td>111</td>33         <td>222</td>34         <td>333</td>35     </tr>36 </table>37 <script>38 //    方式一:分别给每个button增加事件39     var ele_select = ElementsByClassName('select')[0];40     var ele_reserve = ElementsByClassName('reserve')[0];41     var ele_cancel = ElementsByClassName('cancel')[0];42     var ele_input = ElementsByClassName('check');43     //全选44     lick = function () {45         for (var i = 0; i < ele_input.length; i++) {46             //添加一个checked属性47             ele_input[i].checked = 'checked'48         }49     };50     //取消51     lick = function () {52          for (var i =0;i<ele_input.length;i++){53             //删除checked属性,直接设置为空就行了54             ele_input[i].checked = ''55         }56     };57     //反选58     lick = function () {59         for (var i = 0; i < ele_input.length; i++) {60             var ele = ele_input[i];61             if (ele.checked) {//如果选中了就设置checked为空62                 ele.checked = '';63             }64             else {//如果没有就设置checked = checked65                 ele.checked = 'checked';66             }67          }68     };69 70 71 72 73     //方式二:方式一的优化循环增加事件74 //    var ele_button = ElementsByTagName('button');75 //    var ele_input = ElementsByClassName('check');76 //    for(var i=0;i<ele_button.length;i++) {77 //        ele_button[i].onclick = function () {78 //            if (this.innerHTML == '全选') {79 //                for (var i = 0; i < ele_input.length; i++) {80 //                    //添加一个checked属性81 //                    ele_input[i].checked = 'checked'82 //                }83 //            }84 //            else if (this.innerHTML == '取消') {85 //                for (var i = 0; i < ele_input.length; i++) {86 //                    //删除checked属性,直接设置为空就行了87 //                    ele_input[i].checked = ''88 //                }89 //            }90 //            else {91 //                for (var i = 0; i < ele_input.length; i++) {92 //                    var ele = ele_input[i];93 //                    if (ele.checked) {//如果选中了就设置checked为空94 //                        ele.checked = '';95 //                    }96 //                    else {//如果没有就设置checked = checked97 //                        ele.checked = 'checked';98 //                    }99 //                }
100 //            }
101 //        }
102 //    }
103 
104 
105 </script>
106 </body>
107 </html>
表格示例

四、模态对话框

1 <!DOCTYPE html>2 <html lang="en">3 <head>4     <meta charset="UTF-8">5     <title>Title</title>6     <style>7         .back{8             background-color: white;9             height: 2000px;
10         }
11 
12         .shade{
13             position: fixed;
14             top: 0;
15             bottom: 0;
16             left:0;
17             right: 0;
18             background-color: grey;
19             opacity: 0.4;
20         }
21 
22         .hide{
23             display: none;
24         }
25 
26         .models{
27             position: fixed;
28             top: 50%;
29             left: 50%;
30             margin-left: -100px;
31             margin-top: -100px;
32             height: 200px;
33             width: 200px;
34             background-color: wheat;
35 
36         }
37     </style>
38 </head>
39 <body>
40 <div class="back">
41     <input class="c" type="button" value="click">
42 </div>
43 
44 <div class="shade hide handles"></div>
45 
46 <div class="models hide handles">
47     <input class="c" type="button" value="cancel">
48 </div>
49 
50 
51 <script>
52 
53 
54     var eles&#ElementsByClassName("c");
55     var handles&#ElementsByClassName("handles");
56     for(var i=0;i<eles.length;i++){
57         eles[i].οnclick=function(){
58 
59             if(this.value=="click"){
60 
61                 for(var j=0;j<handles.length;j++){
62 
63                     handles[j].ve("hide");
64 
65                  }
66 
67             }
68             else {
69                 for(var j=0;j<handles.length;j++){
70 
71                     handles[j].classList.add("hide");
72                 }
73 
74             }
75         }
76     }
77 
78 </script>
79 
80 </body>
81 </html>
模态对话框

五、搜索框

 1 <!DOCTYPE html>2 <html lang="en">3 <head>4     <meta charset="UTF-8">5     <title>模拟placeholder属性的功能</title>6 </head>7 <body>8 <input type="text" placeholder="username" id="submit">9 <input type="text" value="username" id="submit1">
10 <script>
11 //    var ele = ElementById('submit1');
12     var ele = ElementById('submit1');
13     focus = function () {
14         //先获取焦点,点击输入框就获取到焦点,光标一上去就把值设成空
15         this.value=""
16     };
17     blur = function () {
18 //        当光标不点击那个输入框的时候就失去焦点了
19         //当失去焦点的时候,判断当前的那个值是不是为空,是否含有空格
20 //        如果为空或者有空格,用trim()去掉空格。然后赋值为username
21         if (im()==""){
22             this.value='username'
23         }
24     }
25 </script>
26 </body>
27 </html>
seach示例

六、tab切换

1 <!DOCTYPE html>2 <html lang="en">3 <head>4   <meta charset="UTF-8">5   <title>tab</title>6   <style>7     *{margin:0; padding:0; list-style:none;}8     body{9         font-family: "Helvetica Neue", "Hiragino Sans GB", "Microsoft YaHei", "9ED14F53", Arial, sans-serif;10     }11     h3{12         text-align: center;13         color:darkcyan;14         margin-top: 30px;15         letter-spacing: 5px;16     }17     .box{18       width: 1000px;19       margin:50px auto 0px;20     }21     #title{22       line-height: 40px;23       background-color: rgb(247,247,247);24       font-size: 16px;25       font-weight: bold;26       color: rgb(102,102,102);27     }28     #title span{29       float: left;30       width: 166px;31       text-align: center;32     }33     #title span:hover{34       /*color: black;*/35       cursor: pointer;36     }37     #content{38       margin-top: 20px;39     }40     #content li{41       width: 1050px;42       display: none;43       background-color: rgb(247,247,247);44     }45     #content li div{46       width: 156px;47       margin-right: 14px;48       float: left;49       text-align: center;50     }51     #content li div a{52       font-size: 14px;53       color: black;54       line-height: 14px;55     /*  float: left;*/56     display: inline-block;57       margin-top: 10px;58     }59     #content li a:hover{60       color: #B70606;61     }62     #content li div span{63         font-size: 16px;64         line-height: 16px;65         /*float: left;*/66         display: block;67         color: rgb(102,102,102);68         margin-top: 10px;69       }70     #content img{71       float: left;72       width: 155px;73       height: 250px;74     }75     #title .select{76       background-color: #2459a2;77       color: white;78         border-radius: 10%;79     }80     #content .show{81       display: block;82     }83 84     .show span{85         color: red!important;86         font-size: 30px;87     }88   </style>89 </head>90 91 <body>92     <h3 id="wel">京东商城欢迎您</h3>93     <!--  direction="right up down left" -->94 <!--  behavior:滚动方式(包括3个值:scroll、slide、alternate) -->95 <!--  说明:scroll:循环滚动,默认效果;slide:只滚动一次就停止;alternate:来回交替进行滚动。 -->96 <!--  scrollamount="5" 滚动速度 -->97 98 <marquee behavior="scroll" direction="right">欢迎海燕来访</marquee>99     <script>
100 
101     function test(){
102 
103         var mywel = ElementById("wel");
104         var content = mywel.innerText;
105 
106         var f_content = content.charAt(0);
107         var l_content = content.substring(1,content.length);
108 
109         var new_content = l_content + f_content;
110         mywel.innerText = new_content;
111 
112     }
113 
114     // setInterval("test();", 500);
115 </script>
116     <div class="box">
117       <p id="title">
118         <span class="select">家用电器</span>
119         <span>家具</span>
120         <span>汽车</span>
121         <span>食品</span>
122         <span>女鞋</span>
123         <span>医疗保健</span>
124       </p>
125 
126       <ul id="content">
127         <li class="show">
128 
129           <div><img src=".jpg" alt="冰箱"><a href="#">容声(Ronshen)冰箱</a><span>价格:5600</span></div>
130           <div><img src=".jpg" alt="洗衣机"><a href="#">海尔洗衣机</a><span>价格:5400</span></div>
131           <div><img src=".jpg" alt="电饭煲"><a href="#">福库(CUCKOO)电饭煲</a><span>价格:3999</span></div>
132           <div><img src=".jpg" alt="智能电视"><a href="#">三星智能电视</a><span>价格:8999</span></div>
133           <div><img src=".jpg" alt="净水器"><a href="#">净水器</a><span>价格:1300</span></div>
134           <div><img src=".jpg" alt="空气净化器"><a href="#">空气净化器</a><span>价格:5300</span></div>
135         </li>
136 
137         <li>
138 
139           <div><img src=".jpg" alt="沙发"><a href="#">沙发</a><span>价格:2900</span></div>
140           <div><img src=".jpg" alt="沙发"><a href="#">沙发</a><span>价格:2900</span></div>
141           <div><img src=".jpg" alt="沙发"><a href="#">沙发</a><span>价格:2900</span></div>
142           <div><img src=".jpg" alt="沙发"><a href="#">沙发</a><span>价格:2900</span></div>
143           <div><img src=".jpg" alt="沙发"><a href="#">沙发</a><span>价格:2900</span></div>
144           <div><img src=".jpg" alt="沙发"><a href="#">沙发</a><span>价格:2900</span></div>
145 
146         </li>
147         <li>
148           <div><img src=".jpg" alt="长安汽车"><a href="#">长安汽车</a><span>价格:12900</span></div>
149           <div><img src=".jpg" alt="长安汽车"><a href="#">长安汽车</a><span>价格:12900</span></div>
150           <div><img src=".jpg" alt="长安汽车"><a href="#">长安汽车</a><span>价格:12900</span></div>
151           <div><img src=".jpg" alt="长安汽车"><a href="#">长安汽车</a><span>价格:12900</span></div>
152           <div><img src=".jpg" alt="长安汽车"><a href="#">长安汽车</a><span>价格:12900</span></div>
153           <div><img src=".jpg" alt="长安汽车"><a href="#">长安汽车</a><span>价格:12900</span></div>
154         </li>
155         <li>
156 
157           <div><img src=".jpg" alt="嘉兴粽子"><a href="#">嘉兴粽子</a><span>价格:1</span></div>
158           <div><img src=".jpg" alt="嘉兴粽子"><a href="#">嘉兴粽子</a><span>价格:1</span></div>
159           <div><img src=".jpg" alt="嘉兴粽子"><a href="#">嘉兴粽子</a><span>价格:1</span></div>
160           <div><img src=".jpg" alt="嘉兴粽子"><a href="#">嘉兴粽子</a><span>价格:1</span></div>
161           <div><img src=".jpg" alt="嘉兴粽子"><a href="#">嘉兴粽子</a><span>价格:1</span></div>
162           <div><img src=".jpg" alt="嘉兴粽子"><a href="#">嘉兴粽子</a><span>价格:1</span></div>
163 
164         </li>
165         <li>
166 
167           <div><img src=".jpg" alt="星期六"><a href="#">星期六</a><span>价格:439</span></div>
168           <div><img src=".jpg" alt="星期六"><a href="#">星期六</a><span>价格:439</span></div>
169           <div><img src=".jpg" alt="星期六"><a href="#">星期六</a><span>价格:439</span></div>
170           <div><img src=".jpg" alt="星期六"><a href="#">星期六</a><span>价格:439</span></div>
171           <div><img src=".jpg" alt="星期六"><a href="#">星期六</a><span>价格:439</span></div>
172           <div><img src=".jpg" alt="星期六"><a href="#">星期六</a><span>价格:439</span></div>
173 
174         </li>
175         <li>
176 
177           <div><img src=".jpg" alt="汇仁 肾宝片"><a href="#">汇仁 肾宝片</a><span>价格:322</span></div>
178           <div><img src=".jpg" alt="汇仁 肾宝片"><a href="#">汇仁 肾宝片</a><span>价格:322</span></div>
179           <div><img src=".jpg" alt="汇仁 肾宝片"><a href="#">汇仁 肾宝片</a><span>价格:322</span></div>
180           <div><img src=".jpg" alt="汇仁 肾宝片"><a href="#">汇仁 肾宝片</a><span>价格:322</span></div>
181           <div><img src=".jpg" alt="汇仁 肾宝片"><a href="#">汇仁 肾宝片</a><span>价格:322</span></div>
182           <div><img src=".jpg" alt="汇仁 肾宝片"><a href="#">汇仁 肾宝片</a><span>价格:322</span></div>
183 
184         </li>
185 
186 
187       </ul>
188     </div>
189 
190     <script>
191       var title&#ElementById('title');
192       var content&#ElementById('content');
193       var category&#ElementsByTagName('span');
194       var item&#ElementsByTagName('li');
195 
196       for (var i = 0; i < category.length; i++) {
197 
198           category[i].index=i;
199 
200           category[i].οnclick=function(){
201 
202             for (var j = 0; j < category.length; j++) {
203               category[j].className='';
204               item[j].className='';
205             }
206             this.className='select';
207             item[this.index].className='show';
208           }
209 
210 
211       }
212 
213     </script>
214 </body>
215 </html>
216 
217 tab切换
tab

四、作用链域

 1 <!DOCTYPE html>2 <html lang="en">3 <head>4     <meta charset="UTF-8">5     <title>作用链域</title>6 </head>7 <body>8 <script>9     var s = 12;
10     function f() {
11         console.log(s); //undefined
12         var s=12;
13         console.log(s);//12
14     }
15     f();
16 </script>
17 </body>
18 </html>
作用域链

js的作用域

作用域是JavaScript最重要的概念之一,想要学好JavaScript就需要理解JavaScript作用域和作用域链的工作原理。

任何程序设计语言都有作用域的概念,简单的说,作用域就是变量与函数的可访问范围,即作用域控制着变量与函数的可见性和生命周期。在JavaScript中,变量的作用域有全局作用域和局部作用域两种。

作用域

1. 全局作用域(Global Scope)

在代码中任何地方都能访问到的对象拥有全局作用域,一般来说一下几种情形拥有全局作用域:

(1)最外层函数和在最外层函数外面定义的变量拥有全局作用域

var name="yuan";function foo(){var age=23;function inner(){console.log(age);}inner();}console.log(name);    // yuan//console.log(age);   // Uncaught ReferenceError: age is not definedfoo();                // 23inner();              // Uncaught ReferenceError: inner is not defined

(2)所有末定义直接赋值的变量自动声明为拥有全局作用域,例如:

    var name="yuan";function foo(){age=23;var sex="male"}foo();console.log(age);   //  23console.log(sex);   // sex is not defined

变量blog拥有全局作用域,而sex在函数外部无法访问到。

(3)所有window对象的属性拥有全局作用域

一般情况下,window对象的内置属性都都拥有全局作用域,例如window.alert()、window.location、p等等。

2. 局部作用域(Local Scope)

和全局作用域相反,局部作用域一般只在固定的代码片段内可访问到,最常见的例如函数内部,所有在一些地方也会看到有人把这种作用域成为函数作用域.

如示例1中的age与inner都只有局部作用域。(js中if、for没有自己的作用域)

作用域链(Scope Chain)

在JavaScript中,函数也是对象,实际上,JavaScript里一切都是对象。函数对象和其它对象一样,拥有可以通过代码访问的属性和一系列仅供JavaScript引擎访问的内部属性。其中一个内部属性是[[Scope]],由ECMA-262标准第三版定义,该内部属性包含了函数被创建的作用域中对象的集合,这个集合被称为函数的作用域链,它决定了哪些数据能被函数访问。

示例演示

please have a try:

//-----**********************例1*********************************var s=12;function f(){console.log(s);var s=12;          // if s=12console.log(s)}f();//-----**********************例2*********************************var s=10;
function foo(){console.log(s);var s=5;console.log(s);function s(){console.log("ok")}// 函数的定于或声明是在词法分析时完成的,执行时已不再有任何操作console.log(s);
}foo();//-----***********************例3********************************function bar(age) {console.log(age);var age = 99;
var sex= 'male';console.log(age);function age() {
alert(123)};console.log(age);
return 100; }result=bar(5);//-----********************************************************

结果分析

我相信大家一定会有想不到的结果,接下来我们就以最复杂的例3来分析整个过程。

当一个函数创建后,它的作用域链会被创建此函数的作用域中可访问的数据对象填充。在函数bar创建时,它的作用域链中会填入一个全局对象,该全局对象包含了所有全局变量,如下图所示:

解析到函数调用时,即bar(5),会生成一个active object的对象,该对象包含了函数的所有局部变量、命名参数、参数集合以及this,然后此对象会被推入作用域链的前端,当运行期上下文被销毁,活动对象也随之销毁。新的作用域链如下图所示:

过程解析:

function bar(age) {console.log(age);var age = 99;var sex="male";console.log(age);function age(){alert(123);} ;console.log(age);return 100;
}result=bar(5);一 词法分析过程(涉及参数,局部变量声明,函数声明表达式):1-1 、分析参数,有一个参数,形成一个 AO.age=undefine;1-2 、接收参数 AO.age=5;1-3 、分析变量声明,有一个 var age, 发现 AO 上面有一个 AO.age ,则不做任何处理1-4 、分析变量声明,有一个 var sex,形成一个 AO.sex=undefine;1-5 、分析函数声明,有一个 function age(){} 声明, 则把原有的 age 覆盖成 AO.age=function(){};
二 执行过程:2-1 、执行第一个 console.log(age) 时,当前的 AO.age 是一个函数,所以输出的一个函数2-2 、这句 var age=99; 是对不 AO.age 的属性赋值, AO.age=99 ,所以在第二个输出的age是 99;2-3 、同理第三个输出的是 99, 因为中间没有改变 age 值的语句了。注意:执行阶段:function age(){alert(123)} ;不进行任何操作,将执行语句复制给age这部操作是在词法分析时,即运行前完成的。

 

转载于:.html

本文发布于:2024-02-02 14:47:56,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170685647444511.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:对象   JavaScript   JS   DOM
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23