js之DOM對象三

来源:https://www.cnblogs.com/morgana/archive/2018/03/02/8492755.html
-Advertisement-
Play Games

一、JS中for迴圈遍歷測試 for迴圈遍歷有兩種 第一種:是有條件的那種,例如 for(var i = 0;i<ele.length;i++){} 第二種:for (var i in li ){} 現在我們來說一下測試一下第二種(數組和obj的) 1 <!DOCTYPE html> 2 <html ...


一、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=document.getElementsByTagName("button")[0];
17 
18     ele_button.onclick=function () {
19         var ele_input=document.getElementById("c1");
20         var ele_select=document.getElementById("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 = document.getElementsByClassName('select')[0];
 40     var ele_reserve = document.getElementsByClassName('reserve')[0];
 41     var ele_cancel = document.getElementsByClassName('cancel')[0];
 42     var ele_input = document.getElementsByClassName('check');
 43     //全選
 44     ele_select.onclick = function () {
 45         for (var i = 0; i < ele_input.length; i++) {
 46             //添加一個checked屬性
 47             ele_input[i].checked = 'checked'
 48         }
 49     };
 50     //取消
 51     ele_cancel.onclick = function () {
 52          for (var i =0;i<ele_input.length;i++){
 53             //刪除checked屬性,直接設置為空就行了
 54             ele_input[i].checked = ''
 55         }
 56     };
 57     //反選
 58     ele_reserve.onclick = 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 = checked
 65                 ele.checked = 'checked';
 66             }
 67          }
 68     };
 69 
 70 
 71 
 72 
 73     //方式二:方式一的優化迴圈增加事件
 74 //    var ele_button = document.getElementsByTagName('button');
 75 //    var ele_input = document.getElementsByClassName('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 = checked
 97 //                        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=document.getElementsByClassName("c");
55     var handles=document.getElementsByClassName("handles");
56     for(var i=0;i<eles.length;i++){
57         eles[i].onclick=function(){
58 
59             if(this.value=="click"){
60 
61                 for(var j=0;j<handles.length;j++){
62 
63                     handles[j].classList.remove("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 = document.getElementById('submit1');
12     var ele = document.getElementById('submit1');
13     ele.onfocus = function () {
14         //先獲取焦點,點擊輸入框就獲取到焦點,游標一上去就把值設成空
15         this.value=""
16     };
17     ele.onblur = function () {
18 //        當游標不點擊那個輸入框的時候就失去焦點了
19         //當失去焦點的時候,判斷當前的那個值是不是為空,是否含有空格
20 //        如果為空或者有空格,用trim()去掉空格。然後賦值為username
21         if (this.value.trim()==""){
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", "\9ED1\4F53", 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 = document.getElementById("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="https://img10.360buyimg.com/n1/s450x450_jfs/t4786/325/2470647304/119102/9e1a4ed5/59005841Nd786a8df.jpg" alt="冰箱"><a href="#">容聲(Ronshen)冰箱</a><span>價格:5600</span></div>
130           <div><img src="https://img12.360buyimg.com/n1/s450x450_jfs/t3037/347/1290968859/201366/7c1028a0/57c00194N9d0a54c6.jpg" alt="洗衣機"><a href="#">海爾洗衣機</a><span>價格:5400</span></div>
131           <div><img src="https://img11.360buyimg.com/n1/jfs/t3289/128/2393835119/236360/af1d283b/57e0f300N53dde603.jpg" alt="電飯煲"><a href="#">福庫(CUCKOO)電飯煲</a><span>價格:3999</span></div>
132           <div><img src="https://img13.360buyimg.com/n1/jfs/t3235/137/2361713777/152258/a6908440/57e098c2N44a90a5d.jpg" alt="智能電視"><a href="#">三星智能電視</a><span>價格:8999</span></div>
133           <div><img src="https://img10.360buyimg.com/n1/jfs/t2053/101/1391591157/215066/572e131b/5696ee9bN2376492d.jpg" alt="凈水器"><a href="#">凈水器</a><span>價格:1300</span></div>
134           <div><img src="https://img14.360buyimg.com/n1/jfs/t3175/78/2357430273/262835/9a8e7f65/57e0a3e9Nbda39dd2.jpg" alt="空氣凈化器"><a href="#">空氣凈化器</a><span>價格:5300</span></div>
135         </li>
136 
137         <li>
138 
139           <div><img src="https://img12.360buyimg.com/n1/jfs/t1948/172/2877517581/556924/682eb107/56f63dc8Naddf77e5.jpg" alt="沙發"><a href="#">沙發</a><span>價格:2900</span></div>
140           <div><img src="https://img12.360buyimg.com/n1/jfs/t1948/172/2877517581/556924/682eb107/56f63dc8Naddf77e5.jpg" alt="沙發"><a href="#">沙發</a><span>價格:2900</span></div>
141           <div><img src="https://img12.360buyimg.com/n1/jfs/t1948/172/2877517581/556924/682eb107/56f63dc8Naddf77e5.jpg" alt="沙發"><a href="#">沙發</a><span>價格:2900</span></div>
142           <div><img src="https://img12.360buyimg.com/n1/jfs/t1948/172/2877517581/556924/682eb107/56f63dc8Naddf77e5.jpg" alt="沙發"><a href="#">沙發</a><span>價格:2900</span></div>
143           <div><img src="https://img12.360buyimg.com/n1/jfs/t1948/172/2877517581/556924/682eb107/56f63dc8Naddf77e5.jpg" alt="沙發"><a href="#">沙發</a><span>價格:2900</span></div>
144           <div><img src="https://img12.360buyimg.com/n1/jfs/t1948/172/2877517581/556924/682eb107/56f63dc8Naddf77e5.jpg" alt="沙發"><a href="#">沙發</a><span>價格:2900</span></div>
145 
146         </li>
147         <li>
148           <div><img src="http://img11.360buyimg.com/n1/jfs/t4969/76/45396935/144539/347153d4/58d9cff4N36872ad6.jpg" alt="長安汽車"><a href="#">長安汽車</a><span>價格:12900</span></div>
149           <div><img src="http://img11.360buyimg.com/n1/jfs/t4969/76/45396935/144539/347153d4/58d9cff4N36872ad6.jpg" alt="長安汽車"><a href="#">長安汽車</a><span>價格:12900</span></div>
150           <div><img src="http://img11.360buyimg.com/n1/jfs/t4969/76/45396935/144539/347153d4/58d9cff4N36872ad6.jpg" alt="長安汽車"><a href="#">長安汽車</a><span>價格:12900</span></div>
151           <div><img src="http://img11.360buyimg.com/n1/jfs/t4969/76/45396935/144539/347153d4/58d9cff4N36872ad6.jpg" alt="長安汽車"><a href="#">長安汽車</a><span>價格:12900</span></div>
152           <div><img src="http://img11.360buyimg.com/n1/jfs/t4969/76/45396935/144539/347153d4/58d9cff4N36872ad6.jpg" alt="長安汽車"><a href="#">長安汽車</a><span>價格:12900</span></div>
153           <div><img src="http://img11.360buyimg.com/n1/jfs/t4969/76/45396935/144539/347153d4/58d9cff4N36872ad6.jpg" alt="長安汽車"><a href="#">長安汽車</a><span>價格:12900</span></div>
154         </li>
155         <li>
156 
157           <div><img src="https://img14.360buyimg.com/n1/jfs/t4414/110/2582917360/207971/b7e129ad/58f0ee1fN94425de1.jpg" alt="嘉興粽子"><a href="#">嘉興粽子</a><span>價格:1</span></div>
158           <div><img src="https://img14.360buyimg.com/n1/jfs/t4414/110/2582917360/207971/b7e129ad/58f0ee1fN94425de1.jpg" alt="嘉興粽子"><a href="#">嘉興粽子</a><span>價格:1</span></div>
159           <div><img src="https://img14.360buyimg.com/n1/jfs/t4414/110/2582917360/207971/b7e129ad/58f0ee1fN94425de1.jpg" alt="嘉興粽子"><a href="#">嘉興粽子</a><span>價格:1</span></div>
160           <div><img src="https://img14.360buyimg.com/n1/jfs/t4414/110/2582917360/207971/b7e129ad/58f0ee1fN94425de1.jpg" alt="嘉興粽子"><a href="#">嘉興粽子</a><span>價格:1</span></div>
161           <div><img src="https://img14.360buyimg.com/n1/jfs/t4414/110/2582917360/207971/b7e129ad/58f0ee1fN94425de1.jpg" alt="嘉興粽子"><a href="#">嘉興粽子</a><span>價格:1</span></div>
162           <div><img src="https://img14.360buyimg.com/n1/jfs/t4414/110/2582917360/207971/b7e129ad/58f0ee1fN94425de1.jpg" alt="嘉興粽子"><a href="#">嘉興粽子</a><span>價格:1</span></div>
163 
164         </li>
165         <li>
166 
167           <div><img src="https://img14.360buyimg.com/n1/jfs/t3079/298/5759209435/92674/14818594/587f1c33N53e5d2a9.jpg" alt="星期六"><a href="#">星期六</a><span>價格:439</span></div>
168           <div><img src="https://img14.360buyimg.com/n1/jfs/t3079/298/5759209435/92674/14818594/587f1c33N53e5d2a9.jpg" alt="星期六"><a href="#">星期六</a><span>價格:439</span></div>
169           <div><img src="https://img14.360buyimg.com/n1/jfs/t3079/298/5759209435/92674/14818594/587f1c33N53e5d2a9.jpg" alt="星期六"><a href="#">星期六</a><span>價格:439</span></div>
170           <div><img src="https://img14.360buyimg.com/n1/jfs/t3079/298/5759209435/92674/14818594/587f1c33N53e5d2a9.jpg" alt="星期六"><a href="#">星期六</a><span>價格:439</span></div>
171           <div><img src="https://img14.360buyimg.com/n1/jfs/t3079/298/5759209435/92674/14818594/587f1c33N53e5d2a9.jpg" alt="星期六"><a href="#">星期六</a><span>價格:439</span></div>
172           <div><img src="https://img14.360buyimg.com/n1/jfs/t3079/298/5759209435/92674/14818594/587f1c33N53e5d2a9.jpg" alt="星期六"><a href="#">星期六</a><span>價格:439</span></div>
173 
174         </li>
175         <li>
176 
177           <div><img src="https://img12.360buyimg.com/n1/jfs/t5755/127/1139389729/356866/99d4e869/5923e410Nb2983f70.jpg" alt="匯仁 腎寶片"><a href="#">匯仁 腎寶片</a><span>價格:322</span></div>
178           <div><img src="https://img12.360buyimg.com/n1/jfs/t5755/127/1139389729/356866/99d4e869/5923e410Nb2983f70.jpg" alt="匯仁 腎寶片"><a href="#">匯仁 腎寶片</a><span>價格:322</span></div>
179           <div><img src="https://img12.360buyimg.com/n1/jfs/t5755/127/1139389729/356866/99d4e869/5923e410Nb2983f70.jpg" alt="匯仁 腎寶片"><a href="#">匯仁 腎寶片</a><span>價格:322</span></div>
180           <div><img src="https://img12.360buyimg.com/n1/jfs/t5755/127/1139389729/356866/99d4e869/5923e410Nb2983f70.jpg" alt="匯仁 腎寶片"><a href="#">匯仁 腎寶片</a><span>價格:322</span></div>
181           <div><img src="https://img12.360buyimg.com/n1/jfs/t5755/127/1139389729/356866/99d4e869/5923e410Nb2983f70.jpg" alt="匯仁 腎寶片"><a href="#">匯仁 腎寶片</a><span>價格:322</span></div>
182           <div><img src="https://img12.360buyimg.com/n1/jfs/t5755/127/1139389729/356866/99d4e869/5923e410Nb2983f70.jpg" alt="匯仁 腎寶片"><a href="#">匯仁 腎寶片</a><span>價格:322</span></div>
183 
184         </li>
185 
186 
187       </ul>
188     </div>
189 
190     <script>
191       var title=document.getElementById('title');
192       var content=document.getElementById('content');
193       var category=title.getElementsByTagName('span');
194       var item=content.getElementsByTagName('li');
195 
196       for (var i = 0; i < category.length; i++) {
197 
198           category[i].index=i;
199 
200           category[i].onclick=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>
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 defined
    foo();                // 23
    inner();              // Uncaught ReferenceError: inner is not defined
複製代碼

(2)所有末定義直接賦值的變數自動聲明為擁有全局作用域,例如:

複製代碼
    var name="yuan";

    function foo(){
        age=23;

        var sex="male"
    }
    foo();
    console.log(age);   //  23
    console.log(sex);   // sex is not defined
複製代碼

變數blog擁有全局作用域,而sex在函數外部無法訪問到。

(3)所有window對象的屬性擁有全局作用域

一般情況下,window對象的內置屬性都都擁有全局作用域,例如window.alert()、window.location、window.top等等。

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=12
        console.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這部操作是在詞法分析時,即運行前完成的。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 文檔流的概念指什麼?有哪種方式可以讓元素脫離文檔流? 文檔流,指的是元素排版佈局過程中,元素會自動從左往右,從上往下的流式排列。並最終窗體自上而下分成一行行,併在每行中按從左到右的順序排放元素。脫離文檔流即是元素打亂了這個排列,或是從排版中拿走。 讓元素脫離文檔流的方法有:浮動和定位。 在 CSS ...
  • 頁面HTML: css代碼: ...
  • 如題,以前都是給客戶提供安卓和iOS兩個二維碼,實在覺得麻煩,就是一勞永逸了一下。不會傳附件,需要相關素材的可以私我。 ...
  • 在大多數的瀏覽器中都有實現網頁全屏顯示的功能,並且大部分瀏覽器實現全屏顯示和退出全屏顯示的快捷鍵通常是F11和Esc兩個按鍵。如今,W3C已經制定了關於網頁全屏顯示的API,利用這個API 可以實現網頁的全屏顯示,並且還能將某個特定的元素設置為全屏顯示,在各瀏覽器的相容性:google chrome... ...
  • 看了網上很多資料,對vue的computed講解自己看的都不是很清晰,今天忙裡抽閑,和同事們又閑聊起來,對computed這個屬性才有了一個稍微比較清晰的認識,下麵的文章有一部分是轉自: https://www.w3cplus.com/vue/vue-computed-intro.html © w3 ...
  • 趕緊完結這個系列咯,webpack4都已經出正式版了。 之前的代碼搜索到js文件的對應loader,並添加到了對象中返回,流程如下: 這個對象的request將入口文件的路徑與loader拼接起來並用!分割,所有的屬性基本上都與路徑相關。 after-resolve事件流 這裡會觸發after-re ...
  • 因為JS可以多層嵌套代碼可能下麵還可以再嵌一個方法引用this就會變成子方法控制的對象如果需要上級的對象在沒有參數的情況下前面前提做了一個臨時變數_this可以保存上級對象子方法中就可以用_this來調用了,這才是目的。摘自百度問答:https://zhidao.baidu.com/question ...
  • 什麼是DOM? DOM(Document Object Model)文檔對象模型,是 語言和平臺的中立介面。。 允許程式和腳本動態地訪問和更新文檔的內容 。 為什麼要使用DOM? Dom技術使得 用戶頁面可以動態地變化,如可以動態地顯示或隱藏一個元素,改變它們的屬性,增加一個元素等 ,Dom技術使得 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...