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