好好學一遍JavaScript 筆記(二)

 

  
  
           
  
  
  1. /**  
  2.   * encodeURI跟encodeURIComponent的區別在於encodeURI不對  
  3.   * 特殊字符進行編碼如:冒號、前斜槓、問號和英鎊符號.  
  4.   * 而encodeURIComponent則對它發現的全部非標準字符進行編碼.  
  5.   */   
  6.  var d = "古道西風";    
  7.  //這樣的URL在後臺轉碼獲取事後就能夠解決get方式提交的亂碼問題了.   
  8.  <%--var url = "<%=path%>/users.action?name="+encodeURI(d);--%>   
  9.  //後臺action或者servlet這樣轉碼獲取    
  10.  //String Name=new String(URLDecoder.decode(request.getParameter("name"),"utf-8"));   
  11.       
  12.  alert(encodeURI(d));           
  13.  alert(encodeURIComponent(d));   
  14.     
  15.  /**  
  16.   * 天然還有解碼方法:decodeURI跟decodeURIComponent  
  17.   *   
  18.   */   
  19.  alert(decodeURI(encodeURI(d)));     
  20.  alert(decodeURIComponent(encodeURIComponent(d))); 

javaScript——Math:css

  
  
           
  
  
  1. /**  
  2.   * 判斷一組數中的最大值  
  3.   */   
  4.  var iMax = Math.max(3,5,56,7,13,79);   
  5.  alert(iMax);     
  6.     
  7.  /**  
  8.   * 判斷一組數中的最小值  
  9.   */   
  10.  var iMin = Math.min(3,5,56,7,13,79);   
  11.  alert(iMin);   
  12.     
  13.  /**  
  14.   * 返回數字的絕對值  
  15.   */   
  16.  alert(Math.abs(-9));  

  
  
           
  
  
  1. /**  
  2.   * 把小數舍入成整數  
  3.   * ceil 表示向上取整  
  4.   * round 常規、4舍5入  
  5.   * floor 表示向下取整  
  6.   */   
  7.  alert(Math.ceil(25.1));  //out26   
  8.  alert(Math.round(25.6));  //out26     
  9.  alert(Math.floor(25.9));  //out25 

  
  
           
  
  
  1. //常數;一個用做天然對數的底的數學常數,表示爲 e。e 的近似值爲 2.718281828459045。   
  2. //alert(Math.E);   
  3. /**  
  4.  * exp()方法用於把Math.E升到指定的冪(mi)  
  5.  * log()方法用於返回特定的數字的天然對數  
  6.  * pow()方法用戶把指定的數字升到指定的冪  
  7.  * sqrt()返回指定數字的平方根   
  8.  * acos(x)       返回x的反餘弦值  
  9.  * asin(x)       返回x的反正弦值  
  10.  * atan(x)       返回x的反正切值  
  11.  * atan2(y,x)    返回y/x的反餘弦值  
  12.  * cos(x)        返回x的餘弦值  
  13.  * sin(x)        返回x的正弦值  
  14.  * tan(x)        返回x的正切值  
  15.  */   
  16. alert(Math.log(Math.exp(12)));      
  17.    
  18. alert(Math.pow(2,10));  //1024   
  19.    
  20. /**  
  21.  * 數字的平方根就是它的2/1次冪  
  22.  * 2的2/1次冪就是2的平方根  
  23.  */   
  24. alert(Math.sqrt(4));   

  
  
           
  
  
  1. /**  
  2.   * Math的random()方法   
  3.   * 該方法返回0到1之間的隨機數、不包括0和1  
  4.   */   
  5.  alert(Math.random());   
  6.     
  7.  /**  
  8.   * 返回iFirstValue到iLastValue的之間(包括)的隨機數    
  9.   * @param {Object} iFirstValue 起始值  
  10.   * @param {Object} iLastValue 結束值  
  11.   * @return {TypeName}   
  12.   */   
  13.  function selectFrom(iFirstValue,iLastValue){   
  14.      var iChoices = iLastValue - iFirstValue + 1 ;   
  15.      return Math.floor(Math.random() * iChoices + iFirstValue) ;   
  16.  }    
  17.  //返回1到9的隨機數、包括1跟9   
  18.  alert(selectFrom(1,9));     
  19.     
  20.  /**  
  21.   * 隨機獲取數組中的元素  
  22.   */   
  23.  var array = new Array(45,452,451,4,42,437,343);    
  24.  alert(array[selectFrom(0,array.length-1)]);  

javaScript——建立對象(Object):java

類工廠方式:json

  
  
           
  
  
  1. /**  
  2.   * 類工廠  
  3.   */   
  4.  function createCar(sColor,iDoors,iMpg){   
  5.      var oTempCar = new Object;   
  6.      oTempCar.color = sColor;   
  7.      oTempCar.doors = iDoors ;   
  8.      oTempCar.mpg = iMpg ;   
  9.      oTempCar.showColor = function(){   
  10.          alert(this.color);   
  11.      };   
  12.      return oTempCar ;     
  13.  }   
  14.  var oCar1 = createCar("red",5,33);   
  15.  var oCar2 = createCar("blue",6,23);   
  16.  alert(oCar1.color);     
  17.  oCar2.showColor() ;  

類工廠方式二:數組

  
  
           
  
  
  1. /**  
  2.   * 類工廠2  
  3.   */   
  4.  function showColor(){   
  5.      alert(this.color);   
  6.  }   
  7.     
  8.  function createCar(sColor,iDoors,iMpg){   
  9.      var oTempCar = new Object;   
  10.      oTempCar.color = sColor;   
  11.      oTempCar.doors = iDoors ;   
  12.      oTempCar.mpg = iMpg ;   
  13.      oTempCar.showColor = showColor;     
  14.      return oTempCar ;     
  15.  }        
  16.  var oCar1 = createCar("red",5,33);   
  17.  var oCar2 = createCar("blue",6,23);   
  18.  alert(oCar1.color);     
  19.  oCar2.showColor();   

構造函數:dom

  
  
           
  
  
  1. /**  
  2.   * 構造函數  
  3.   * @param {Object} sColor  
  4.   * @param {Object} iDoors  
  5.   * @param {Object} iMpg  
  6.   * @memberOf {TypeName}   
  7.   */   
  8.  function Car(sColor,iDoors,iMpg){   
  9.      this.color = sColor;   
  10.      this.doors = iDoors ;   
  11.      this.mpg = iMpg ;   
  12.      this.showColor = function(){   
  13.          alert(this.color);   
  14.      };   
  15.  }      
  16.  var oCar1 = new Car("red",5,33);   
  17.  var oCar2 = new Car("blue",6,23);   
  18.  alert(oCar1.color);     
  19.  oCar2.showColor();   

原型方式:ide

  
  
           
  
  
  1. /**  
  2.   * 原型方式  
  3.   */   
  4.  function Car(){   
  5.  }   
  6.  Car.prototype.color = "red";   
  7.  Car.prototype.doors = 2 ;   
  8.  Car.prototype.mpg = 23 ;   
  9.  Car.prototype.array = new Array(1,2);   
  10.  Car.prototype.showColor = function(){   
  11.      alert(this.color);   
  12.  };   
  13.  var oCar1 = new Car();   
  14.  var oCar2 = new Car();   
  15.  oCar1.color = "blue";   
  16.  oCar1.array.push(3,4) ;    
  17.  alert(oCar1.color);       
  18.  alert(oCar2.color);    
  19.       
  20.  //因爲Array是引用值、array都指向一樣數組   
  21.  alert(oCar1.array);   
  22.  alert(oCar2.array);   

聯合使用構造函數和原型方式:函數

  
  
           
  
  
  1. /**  
  2.   * 聯合使用構造函數和原型方式、就可像用其餘程序設計語言同樣建立對象。  
  3.   * 這種概念很是簡單、即用構造函數定義對象的全部非函數屬性、用原型方式定義對象的函數屬性(方法)。  
  4.   * 結果全部函數都只建立一次、而每一個對象都具備本身的對象屬性實例。    
  5.   */   
  6.  function Car(sColor,iDoors,iMpg){   
  7.      this.color = sColor;   
  8.      this.doors = iDoors ;   
  9.      this.mpg = iMpg ;   
  10.      this.array = new Array(1,2);   
  11.      this.showColor = function(){   
  12.          alert(this.color);   
  13.      };   
  14.  }    
  15.  Car.prototype.array = function (){   
  16.      alert(this.color);     
  17.  };      
  18.  var oCar1 = new Car("red",5,33);   
  19.  var oCar2 = new Car("blue",6,23);   
  20.  oCar1.array.push(4,9);   
  21.  alert(oCar1.array);     
  22.  alert(oCar2.array);   

動態原型方法:this

  
  
           
  
  
  1. /**  
  2.   * 動態原型方法  
  3.   */   
  4.  function Car(sColor,iDoors,iMpg){   
  5.      this.color = sColor;   
  6.      this.doors = iDoors ;   
  7.      this.mpg = iMpg ;   
  8.      if(typeof Car._initialized == "undefined"){   
  9.          Car.prototype.showColor = function(){   
  10.              alert(this.color);    
  11.          };   
  12.          Car._initialized = true ;   
  13.      }   
  14.  }        
  15.  var oCar1 = new Car("red",5,33);      
  16.  var oCar2 = new Car("blue",6,23);     
  17.  alert(oCar1.color);     
  18.  oCar2.showColor();   

混合工廠方式:編碼

  
  
           
  
  
  1. /**  
  2.   * 混合工廠方式  
  3.   */   
  4.  function Car(){   
  5.      var oTempCar = new Object;   
  6.      oTempCar.color = "red";   
  7.      oTempCar.doors = 2 ;   
  8.      oTempCar.mpg = 23 ;   
  9.      oTempCar.showColor = function(){      
  10.          alert(this.color);    
  11.      };   
  12.      return oTempCar ;     
  13.  }   
  14.  var oCar1 = new Car();   
  15.  var oCar2 = new Car();       
  16.  alert(oCar1.color);     
  17.  oCar2.showColor();  

利用json建立對象:url

  
  
           
  
  
  1. /**  
  2.   * 利用json建立對象  
  3.   */   
  4.  var Car = {};   
  5.  Car.color = "red";   
  6.  Car.doors = 2;   
  7.  Car.mpg = 23;   
  8.  Car.array = new Array(1,2);   
  9.  Car.showArray = function(){   
  10.    alert(this.array);     
  11.  };   
  12. var oCar = Car;   
  13. oCar.showArray();   

目前使用最普遍的是混合的構造函數/原型方式。此外、動態原型方法也很流行、 在功能上與構造函數/原型方式等價。可採用這兩種方式的任何一種、 不過不要單獨使用經典的構造函數或原型方式、由於這樣會給代碼引入問題。

相關文章
相關標籤/搜索