99久久精品国产片-99久久精品国产免费-99久久精品国产麻豆-99久久精品国产国产毛片-99久久精品国产高清一区二区-99久久精品费精品国产一区二区

【舉栗說明】JavaScript作用域,一次性給你總結!

2021-10-18    前端達人

圖片

本文重點

  • 函數案例

  • 函數作為參數使用

  • arguments

  • 作用域:寫代碼要注意變量的在哪聲明和使用的問題

  • 預解析:什么叫預解析, 什么東西發生了什么事

01 作用域:使用范圍

全局變量:

  • 聲明的變量是使用var聲明的,那么這個變量就是全局變量,

  • 全局變量可以在頁面的任何位置使用

  • 除了函數以外,其他的任何位置定義的變量都是全局變量

  • 如果頁面不關閉,那么就不會釋放,就會占空間,消耗內存

  • 全局作用域:全局變量的使用范圍

局部變量:

  • 在函數內部定義的變量,是局部變量,外面不能使用

  • 局部作用域:局部變量的使用范圍

注意:

塊級作用域:一對大括號就可以看成是一塊,在這塊區域中定義的變量,只能在這個區域中使用,但是在js中在這個塊級作用域中定義的變量,外面也能使用;

說明:js沒有塊級作用域,只有函數除外

隱式全局變量:聲明的變量沒有var,就叫隱式全局變量

全局變量是不能被刪除的,隱式全局變量是可以被刪除的

定義變量使用var是不會被刪除的,沒有var是可以刪除的

function f1() {  number=1000;//是隱式全局變量 }f1();console.log(number);   var num1=10;  num2=20;  delete num1;//把num1刪除了  delete num2;//把num2刪除了  console.log(typeof num1);  console.log(num1+10);  console.log(typeof num2);  num=100; console.log(num);  function f1() {  var num=100;  num+=10; }f1();//這個函數結束之后 { var num=10;  console.log(num);//10 }console.log(num);  if(true){  var num=10; }console.log(num); for(var i=0;i<5;i++){  var number=20; }console.log(number);   var i=0;  while (i<5){  var num=100;  i++;  } console.log(num);  function f1() {  var num=10; }f1(); console.log(num);  var num=10; console.log(num);//10  

作用域鏈

 var num=10;  function f1() {  var num=20;  function f2() {  var num=30;  function f3() {  var num=50;  console.log(num);  } f3();  } f2();  } f1(); 

03 函數案例

求2個數中的最大值

 function getMax(num1, num2) {  return num1 > num2 ? num1 : num2;  } console.log(getMax(10,20));  //console.log(getMax);//函數的代碼 function getMax(num1, num2) {  return num1 > num2 ? num1 : num2;  } var num1=10;  var num2=20;  //函數外面的num1和函數的形參num1不是同一個變量 var result=getMax(num1,num2);  console.log(result);  console.log(getMax);//函數的代碼 

求3個數中的最大值

 function getThreeMax(x, y, z) {  return x > y ? (x > z ? x : z) : (y > z ? y : z);  } console.log(getThreeMax(10,2,24)); 

判斷一個數是否是素數(質數),只能被1和自身整除,質數是從2開始

用這個數字和這個數字前面的所有的數字整除一次(沒有1的,沒有自身的)

 function isPrimeNumber(num) {  for (var i = 2; i < num; i++) {  if (num % i == 0) {  //說明有一個數字整除了,就沒有必要向后繼續整除了, //此時就已經驗證出不是質數 return false;  } } return true;  }//  console.log(isPrimeNumber(7) ? "yyyyyes" : "nnnnnno") var aa = isPrimeNumber(17);  if (aa) {  console.log("yes");  } else {  console.log("no");  }  function isPrimeNumber(num) {  for(var i=2;i<num;i++){  if(num%i==0){  //說明有一個數字整除了,就沒有必要向后繼續整除了,此時就已經驗證出不是質數 return false;  } } return true;  } console.log(isPrimeNumber(8)?"是質數":"不是質數");   var result=isPrimeNumber(2);  if(result){  console.log("這個數字是質數");  }else{  console.log("這個數字不是質數");  }  function aaa(x,y){  return x-y;  } console.log(aaa(99,88)) 

通過函數實現數組反轉

 function reverseArray(arr) {  for (var i = 0; i < arr.length / 2; i++) {  var temp = arr[i];  arr[i] = arr[arr.length - 1 - i];  arr[arr.length - 1 - i] = temp;  } return arr;  } console.log(reverseArray([1, 2, 3, 4, 5])); 

通過函數實現冒泡排序

 function sortArray(arr) {  //控制比較的輪數 for (var i = 0; i < arr.length - 1; i++) {  //控制每一輪的比較次數 for (var j = 0; j < arr.length - 1 - i; j++) {  if (arr[j] > arr[j + 1]) {  var temp = arr[j];  arr[j] = arr[j + 1];  arr[j + 1] = temp;  }//end if }//end for }//end for return arr; } console.log(sortArray([0, 19, 34, 10, 100, 2])); 

求一個數字的階乘

function getJieCheng(num) {  var result = 1;  for (var i = 1; i <= num; i++) {  result *= i;  } return result; }console.log(getJieCheng(5));//1*2*3*4*5 

求斐波那契數列

 function getFib(num){  var num1=1;  var num2=1;  var num3=0;  for(var i=3;i<=nnum;i++){  sum=num1+num2;  num1=num2;  num2=sum;  } return sum;  } console.log(getFib(12))  

02 函數作為參數使用

函數是有數據類型,數據類型:是function類型的

函數可以作為參數使用,如果一個函數作為參數,那么我們說這個參數(函數)可以叫回調函數 只要是看到一個函數作為參數使用了,那就是回調函數

function sayHi(fn) {   console.log("GOOD");  fn();//fn此時應該是一個函數}function suSay() {  console.log("HELLO"); }sayHi(suSay); function f1(x,y) {  console.log(x+y); }f1(10,20); function f2(x,y) {  console.log(x+y); }f2("HLS","MISS"); function f3(x) {  console.log(x); }f3(true);

04 arguments

計算n個數字的和

定義一個函數,如果不確定用戶是否傳入了參數,或者說不知道用戶傳了幾個參數,沒辦法計算,但是如果在函數中知道了參數的個數,等于也知道了每個參數的值.

//定義function f1() {  //獲取的是函數在調用的時候,傳入了幾個參數 //console.log(arguments.length);  //使用arguments對象可以獲取傳入的每個參數的值 console.log(arguments); } f1(10,20,30,40,100,200);//調用 
 function f1({  //arguments----->數組使用------偽數組--- var sum=0;  for(var i=0;i<arguments.length;i++){  sum+=arguments[i];  } return sum;  } console.log(f1(10,20,30)); 

05 預解析:提前解析代碼

預解析:就是在解析代碼之前,預解析做什么事?

把變量的聲明提前了----提前到當前所在的作用域的最上面

函數的聲明也會被提前—提前到當前所在的作用域的最上面

函數調用的時候, 把會函數的聲明提升到作用域的上面

函數的聲明提升到作用域

 f1();//調用  var num=20;//這個變量的聲明會提升到變量使用之前  function f1() {  console.log(num);  //var num=10;  } function f1() {  console.log("小蘇好猥瑣");  } f1();  function f1() {  console.log("小蘇沒有助教猥瑣");  } f1(); 

把變量的聲明提前

 var num;  console.log(num);  num=10;  function f1() {  console.log("哈哈,助教好猥瑣哦");  }   //f1();//報錯 

注意:預解析中,變量的提升,只會在當前的作用域中提升,提前到當前的作用域的最上面

  function f1({  console.log(num);//undefined  var num = 10;  } f1();   console.log(num);//報錯  

函數中的變量只會提前到函數的作用域中的最前面,不會出去

預解析會分段(多對的script標簽中函數重名,預解析的時候不會沖突)

 function f1({  console.log(num);//undefined  var num=10; } f1(); console.log(num);// function f1() { console.log("哈哈"); }

藍藍設計建立了UI設計分享群,每天會分享國內外的一些優秀設計,如果有興趣的話,可以進入一起成長學習,請掃碼藍小助,報下信息,藍小助會請您入群。歡迎您加入噢~~希望得到建議咨詢、商務合作,也請與我們聯系。

分享此文一切功德,皆悉回向給文章原作者及眾讀者.

轉自:csdn
免責聲明:藍藍設計尊重原作者,文章的版權歸原作者。如涉及版權問題,請及時與我們取得聯系,我們立即更正或刪除。

藍藍設計www.lapeinture.cn )是一家專注而深入的界面設計公司,為期望卓越的國內外企業提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、 網站建設 平面設計服務

日歷

鏈接

個人資料

藍藍設計的小編 http://www.lapeinture.cn

存檔

国产视频在线免费观看| 国产国语对白一级毛片| 日本特黄一级| 中文字幕一区二区三区精彩视频| 日韩中文字幕在线观看视频| 99久久精品费精品国产一区二区| 精品国产一区二区三区精东影业| 一 级 黄 中国色 片| 台湾毛片| 亚洲女初尝黑人巨高清在线观看| 欧美激情一区二区三区视频高清| 精品久久久久久免费影院| 成人av在线播放| 免费一级片在线观看| 青青久久国产成人免费网站| 国产一级生活片| 国产精品自拍在线观看| 亚久久伊人精品青青草原2020| 国产韩国精品一区二区三区| 国产福利免费观看| 午夜精品国产自在现线拍| 免费国产在线视频| 精品视频一区二区三区| 高清一级片| 成人高清护士在线播放| 日本在线播放一区| 亚洲精品久久久中文字| 精品国产亚洲一区二区三区| 亚洲 男人 天堂| 日韩男人天堂| 99热精品在线| 日本在线不卡视频| 亚洲爆爽| 999精品视频在线| 91麻豆高清国产在线播放| 精品视频一区二区三区免费| 国产一区二区精品在线观看| 亚洲第一色在线| 国产极品精频在线观看| 亚洲精品中文字幕久久久久久| 国产亚洲精品成人a在线| 天堂网中文在线| 欧美大片a一级毛片视频| 99久久精品国产高清一区二区| 日本免费看视频| 91麻豆精品国产自产在线观看一区| 精品国产一区二区三区精东影业 | 国产一区二区精品久久91| 黄视频网站在线看| 四虎精品在线观看| 97视频免费在线观看| 成人免费观看视频| 可以免费看污视频的网站| 日本免费看视频| 精品视频在线观看一区二区| 久久精品店| 亚洲爆爽| 欧美大片一区| 国产不卡精品一区二区三区| a级毛片免费全部播放| 成人影院一区二区三区| 久久国产精品自由自在| 在线观看成人网 | 久久国产精品只做精品| 成人免费高清视频| 91麻豆精品国产高清在线| 免费毛片播放| 九九免费高清在线观看视频| 四虎影视库国产精品一区| 国产91素人搭讪系列天堂| 国产伦理精品| 青青青草视频在线观看| 亚洲 欧美 91| 青青青草视频在线观看| 久久国产精品自由自在| 日韩一级黄色大片| 亚洲天堂在线播放| 国产极品精频在线观看| 国产不卡高清| 久久99中文字幕| 欧美电影免费| 久久久久久久久综合影视网| 色综合久久手机在线| 天堂网中文字幕| 黄色免费三级| 美女免费黄网站| 久久国产精品自由自在| 国产a毛片| 成人高清免费| 欧美激情在线精品video| 色综合久久天天综合观看| 999精品视频在线| 久久精品欧美一区二区| 999精品在线| 黄视频网站免费| 国产一区二区精品| 成人免费网站视频ww| 一本高清在线| 欧美另类videosbestsex久久| 四虎影视库国产精品一区| 日韩在线观看视频黄| 欧美一级视频高清片| 免费一级片在线观看| 青青青草影院| 精品视频在线观看一区二区三区| 成人高清视频在线观看| 精品国产三级a∨在线观看| 毛片高清| 高清一级片| 成人免费网站久久久| 国产网站免费观看| 国产伦精品一区三区视频| 精品国产亚洲人成在线| 美女免费精品视频在线观看| 欧美a免费| 久久国产精品自线拍免费| 亚欧成人毛片一区二区三区四区 | 久久国产精品自由自在| 香蕉视频久久| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 久久精品成人一区二区三区| 成人a大片在线观看| a级精品九九九大片免费看| 欧美电影免费看大全| 久久99这里只有精品国产| 九九免费精品视频| 国产不卡高清在线观看视频| 韩国妈妈的朋友在线播放| 青青青草影院 | 日日日夜夜操| 99久久精品国产免费| 精品视频免费看| 日本伦理黄色大片在线观看网站| 天天做日日爱| 亚洲精品影院| 国产美女在线观看| 色综合久久天天综合| 日日夜人人澡人人澡人人看免| 国产视频一区二区在线播放| 尤物视频网站在线| 亚洲www美色| 国产伦精品一区二区三区无广告 | 四虎久久影院| 天天做日日爱| 国产伦精品一区二区三区在线观看| 日本伦理片网站| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 国产a视频| 麻豆午夜视频| 午夜精品国产自在现线拍| 青青久久网| 韩国毛片| 午夜激情视频在线观看 | 91麻豆精品国产综合久久久| 欧美大片毛片aaa免费看| 亚洲女人国产香蕉久久精品| 精品国产三级a| 久久久成人网| 日本特黄特色aa大片免费| 精品在线观看国产| 日日日夜夜操| 日日日夜夜操| 深夜做爰性大片中文| 日韩在线观看视频黄| 欧美一级视频免费观看| 国产成人精品综合久久久| 美女免费精品视频在线观看| 精品国产一区二区三区精东影业| 亚欧乱色一区二区三区| 四虎久久影院| 国产一区二区精品在线观看| 韩国三级视频在线观看| 亚欧视频在线| 久久久久久久男人的天堂| 韩国毛片免费大片| 91麻豆国产级在线| 四虎影视久久久| 成人高清视频在线观看| 一本伊大人香蕉高清在线观看| 国产不卡高清在线观看视频| 91麻豆精品国产综合久久久| 亚洲精品中文字幕久久久久久| 精品国产一区二区三区久久久蜜臀| 亚洲www美色| a级毛片免费观看网站| 欧美激情中文字幕一区二区| 国产网站在线| 欧美1区2区3区| 亚洲天堂在线播放| 免费国产在线观看| 青青久在线视频| 四虎久久影院| 一级女性全黄久久生活片| 999久久66久6只有精品| 黄视频网站在线观看| 日本伦理片网站| 精品国产香蕉伊思人在线又爽又黄| 韩国毛片免费大片| 一级毛片看真人在线视频| 国产麻豆精品免费密入口|