国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

javascript類型系統 Window對象學習筆記

2019-11-20 10:50:54
字體:
來源:轉載
供稿:網友

window對象是Web瀏覽器中javascript的一個終極兜底兒對象,在作用域中處于最末端,是一個包含所有對象的對象。所有在全局作用域中定義的屬性和函數都是window對象的屬性

var myStringVar = 'myString';var myFunctionVar = function(){};console.log('myStringVar' in window);//trueconsole.log('myFunctionVar' in window);//true
 

1、引用

  通常有兩種引用window對象的方法。第一種是簡單引用賦予window對象的名稱;第二種是在全局作用域中使用this關鍵字

var foo ='bar';windowRef1 = window;windowRef2 = this;console.log(windowRef1,windowRef2);//輸出window對象的引用console.log(windowRef1.foo,windowRef2.foo);//'bar' 'bar' 

2、特性

  window對象是隱式的,通常不顯式引用;即使window對象顯式聲明,它也是隱式的,因為window對象在作用域鏈中是最后一個

//window.alert()和alert()語句基本上是相同的var foo = {//window對象在這里是隱式的,window.foo fooMethod: function(){  alert('foo' + 'bar');//window對象在這里是隱式的,window.alert  window.alert('foo' + 'bar');//顯式調用window對象,效果一樣 }}foo.fooMethod();//window對象在這里是隱式的,window.foo.fooMethod()

3、屬性
  window對象共有18個屬性

undefined NaN Infinity Boolean String Number Object Array Function Date RegExp Error EvalError RangeError ReferenceError SyntaxError TypeError URIError 

[注意]禁止給undefined、NaN和Infinity賦值

 4、方法

  Javascript附帶一些預定義函數,被認為是window對象的方法

1)、編碼方法

encodeURI():對整個URI進行編碼,用特殊的UTF-8替換所有無效的字符

encodeURI()的不編碼字符有82個:

! # $ & ' ( ) * + , - . / : ; = ? @ _ ~ 0-9 a-z A-Z
encodeURIComponent():對URI的某一段進行編碼(常用于GET方法傳遞參數),用特殊的UTF-8替換所有無效的字符

  一般來說,使用encodeURIComponent()比encodeURI()要多,因為在實踐中更常見的是查詢字符串參數而不是對基礎URI編碼。encodeURIComponent()的不編碼字符有71個:

!  ' ( ) * - . _ ~ 0-9 a-z A-Z
escape():對字符串進行編碼,將字符的unicode編碼轉化為16進制序列

  ES3中反對escape()的使用,并建議用encodeURI和encodeURIComponent代替,不過escape()依然被廣泛的用于cookie的編碼,因為escape()恰好編碼了cookie中的非法字符并且對路徑中常出現的“/”不進行編碼。escape()的不編碼字符有69個:

* + - . / @ _ 0-9 a-z A-Z
decodeURI():解碼encodeURI()

decodeURIComponent():解碼encodeURIComponent()

unescape():解碼escape()

var uri = "http://www.wrox.com/illegal value.htm#start";console.log(encodeURI(uri));//http://www.wrox.com/illegal%20value.htm#startconsole.log(encodeURIComponent(uri));//http%3A%2F%2Fwww.wrox.com%2Fillegal%20value.htm%23startconsole.log(escape(uri));//http%3A//www.wrox.com/illegal%20value.htm%23startvar uri = 'http%3A%2F%2Fwww.wrox.com%2Fillegal%20value.htm%23start';console.log(decodeURI(uri));//http%3A%2F%2Fwww.wrox.com%2Fillegal value.htm%23startconsole.log(decodeURIComponent(uri));//http://www.wrox.com/illegal value.htm#startconsole.log(unescape(uri));//http://www.wrox.com/illegal value.htm#start

eval()

  eval()方法像一個完整的ECMAScript解析器,只接受一個參數,即要執行的JavaScript字符串。當解析器發現代碼中調用eval()方法時,它會將傳入的參數當作實際的ECMAScript語句來解析,然后把執行結果插入到原位置。eval()方法能夠解釋字符串的能力非常強大,但也非常危險。當用它執行用戶輸入數據時,可能會有惡意用戶輸入威脅站點或應用程序字符的代碼,就是所謂的代碼注入

  [注意]在嚴格模式下,外部訪問不到eval()中創建的任何變量或函數,為eval賦值也會導致錯誤 

2)、數字方法

  Window對象下還有isFinite()、isNaN()、parseFloat()、parseInt()這四個關于數字的方法

以上就是本文的全部內容,希望對大家的學習有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 遂平县| 承德市| 中江县| 德保县| 竹山县| 长葛市| 景宁| 东至县| 夏河县| 承德县| 衡南县| 哈密市| 大理市| 榕江县| 确山县| 舞钢市| 锡林郭勒盟| 常州市| 进贤县| 云林县| 中牟县| 扬中市| 曲周县| 西平县| 油尖旺区| 建湖县| 界首市| 乐至县| 区。| 定安县| 普格县| 徐闻县| 武穴市| 古交市| 海原县| 海伦市| 宜城市| 惠东县| 巴东县| 泗洪县| 车险|