JavaScript-基礎文法(4)

來源:互聯網
上載者:User

JavaScript-基礎文法(4)
全域方法,和Number對象

示範global的全域方法 和 Number

  alert(parseInt("123"+1));         outln(parseInt("abc"));//NaN,非法         var val = parseInt("abc");         outln("value = "+isNaN(val));//isNaN判斷是否非法         var val2 = parseInt("123afsa");//val2 = 123         outln(val2);//需要注意的是,如果參數開頭是數字,parseInt方法會保留前面的有效數字,後面捨棄         //而數字放後面,就不會轉化,所以一般用Regex來判斷其中的各元素是否是有效數字          //指定進位格式轉十進位         var val3 = parseInt("123",10);//123         var val4 = parseInt("110",2);//6,            //將十進位轉其他進位,需要用到Number對象         var num = new Number(6);         outln(num.toString(2));//110,將6指定為二進位            var num1 = 60;//這裡沒有new Number         outln(num1.toString(16));//3c         //注意此處可能有疑問,就是num1是一個數值,而數值怎麼能用toString()方法呢         //Js是基於對象的,無論寫神碼)變數,函數等等)在底層都是對象,         //所以用到Number時,很少用到new Number,這類似於Java中的自動裝箱

Js的特有語句for in語句:


格式,for(變數 in 對象)//對對象進行遍曆的語句
for(i in arr){
document.writeln(i);
}

Js自訂對象

因為是Js是基於對象,所以他不具備描述事物的能力,但是在Js中可以用函數來類比物件導向的描述

第一種:給對象添更多的屬性和行為
function Person(){//相當於構造器           // alert("Person 構造器 run");        }         //通過描述進行對象的建立,new         var p = new Person();         //Js中給對象添加屬性,用p.屬性名稱即可        p.name = "a";        p.age = 1;        p.show = function(){//定義p對象的函數            alert("show is running"+this.name+this.age);        }        p.show();

第二種:用於封裝,更多的是在描述事物

function Person(name,age){            this.name = name;            this.age = age;            this.setName = function(name){                this.name = name;            }            this.getName = function(){                return this.name;            }        }         var p = new Person("a",1);         alert(p.getName());



第三中:使用{}定義屬性和值的鍵值對方式

var P = {            name:"haha" ,"age":100,//索引值對,值必須是冒號,鍵可以不是            "getName":function(){ //索引值對 與 索引值對之間用 逗號隔開                return this.name;            },getAge:function(){                return this.age;            }        }           // alert(P.getAge());//注意檢測不嚴格,寫成小寫p,也不報錯                //對象調用成員有兩種方式,對象.屬性名稱  對象["屬性名稱"]       alert(P["name"]);        alert(P["name"]+P["getAge"]());//注意調用方法後面要加()/*      function Person(name,age){          this.name = name;          this.age = age;          this.setName = function(name){              this.name = name;          }          this.getName = function(){              return this.name;          }      }      var p = new Person("a",1);      for(i in p){          document.writeln(p[i]);      } */         var map = {             3:"你",5:"我",4:"它"         }         /*for(i in map){             document.writeln(map[i]);         }         outln(map["5"]);//注意如果是數字就可以不加“”         */         var getKey = function(key){             return map[key];         }         var mm = getKey(5);         alert(mm);

Js的一些命名格式

定義一個物件變數,oXX
int型變數 iXX
布爾型 bXX
String型變數 sXX

一些複雜定義格式
  var mm = {          // name:["sdf","sd","dfg","cd"],age:[13,11,12,13]           names:[{name:"a"},{name:"b"},{name:"c"}]       }         //alert(mm.name[2]);         //alert(mm.names[1].name);         for(var i = 0;i

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.