js封装

作为以为麻袋前端,js弱到不行,快忘了,写一些函数的封装复习一下

1、queryUrlParamter封装
var str="www.baidu.com?hfkjh=hdj&hdfjdg=gfdhsg"
String.prototype.queryUp=function(){
//返回一个对象
var obj={};
var reg=/([^?=&]+)=([^?=&]+)/g;
this.replace(reg,function($0,$1,$2){
obj[&1]=$2
})
return obj;
}
fomatDate封装;
var strDate='2017-6-13 0:20:30'
var str='{0}年{1}月{2}日 {3}时{4}分{5}秒'
//思路:strDate变成数组,匹配str中的模版String.prototype.fomatDate=function(str){
    var StrAry=this.match(/\d+/g);
    return str.replace(/{\d+}/g,function($0,$1,$2){
    var tmp=ary[$1];
    tmp=tmp>=0&&tmp<10?'0'+tmp:tmp
    return tmp
})
}
console.log(strDate.fomatDate(str))
共有属性封装hasPubProperty;
function hasPubProperty(attr,obj){
return attr in obj&&!obj.hasOwnProperty(obj)
}
createObject 封装
function createObject(obj2){
    function F(){}
    F.prototype=obj2;
    return new F;
}
var obj=createObject(obj2)//这样obj就具备了obj2的属性
match(批量捕获) 是es5产生的方法针对与ie当然是不兼容啦!
var str='fhjshfj13123123hsdjfhj131231jdhajkshdaj13123',reg=/\d+/g;捕获数字
String.prototype.myMatch=function(reg){
var ary=[],res=reg.exec(this)
//对str进行正则捕到数组中
while(res){
ary.push(res[0]);
res.exec(this)
}
return ary
}
console.log(str.myMatch(reg))
封装forEach,ie9一下不兼容,和长度有关系!
var ary=[12,12,13,14,15,16];
var b={};
Array.prototype.myForeach=function(a,b){
b=b||window;
if('forEach' in Array.prototype){
this.forEach(a,b)
return;
}
for(var i=0;i<this.length;i++){
    a.call(b,this[i],i,this)
}
ary.myForeach(function(item,index,array){
//这里有三个参数,第一个是遍历的内容,第二个是索引,第三个是本身;
},b)
同理我们可以封装map ie不兼容
var ary=[12,12,13,14,15,16];
var b={};
Array.prototype.myForeach=function(a,b){
b=b||window;
if('map' in Array.prototype){
this.forEach(a,b)
return;
}
var ary=[];
for(var i=0;i<this.length;i++){
    var a=a.call(b,this[i],i,this)
    ary.push(a);
}
return ary;
}
ary.myForeach(function(item,index,array){
//这里有三个参数,第一个是遍历的内容,第二个是索引,第三个是本身;
},b)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值