javascript对象基础(使用对象)---4对象、属性、方法的高级操作-Fucntion和String

ECMAScript5为Function增加了一个原型方法bind(Function.prototype.bind), 用来把函数绑定到指定对象上

function.bind(thisArg[,arg1[,arg2[,arg3]]]);其中thisArg,this关键字可在新函数中引用的对象

例:

   var checkNumericRange=function(value){

     if(typeof  value !=='number')

          return  false;

    else  

         return  value>=this.minimum&&value<=this.maimum;

}

var range={minimum:10,maximum:20};

var boundCheckNumericRange= checkNumericRange.bind(range);//注意  bind(括号里面是  对象)

扫描二维码关注公众号,回复: 4808820 查看本文章

var result=boundCheckNumericRange(12)// true

例2:

var originalObject={

  minimum:50,

  maximum:100,

var checkNumericRange=function(value){

     if(typeof  value !=='number')

          return  false;

    else  

         return  value>=this.minimum&&value<=this.maimum;

}

}

var  result=originalObject. checkNumericRange(10);

document.write(result);// false  ,此时的this指向originalObject  ,

range={minimum:10,maximum:20};

var boundObjectWithRange=originalObject.checkNumericRange.bind(range);//this现在指向range对象

var result=boundObjectWithRange(10);

document.write(result);// true,说明bind改变了函数的this指向,this现在指向bind括号里面的对象,即绑定的那个对象

例3,利用bind为函数两次传递参数,实现连续参数求值计算

var displayArgs=function(val1,val2,val3,val4){

   document.write(val1+" "+val2+" "+val3+" "+val4)

}

var emptyObject={};

var displayArgs2=displayArgs.bind(emptyObject,12,"a");

displayArgs2("b","c");// 12 a  b  c

String:ECMAScript5新增了trim()方法利用该方法可以从字符串中移除前导空格、尾随空格、行终止符

  stringObj.trim() --移除空格 、tab制表符、回车符、换行符

  var message="      abc  def     \r\n   ";

document.write("["+message.trim()+"]");  //[abc def],注意字母中间的空格  是不会去除的

document.write("</br>");

document.write("length"+message.trim().length);  //7

猜你喜欢

转载自blog.csdn.net/wenmin1987/article/details/85643041