实例为日常开发常用的小实例,包括数组去重,打乱数组,字母大小写转换,cookie操作的封装等。
//去除空格
ecDo.trim(' xx x x',1);
//xxxx
//大小写转换
ecDo.changeCase('asdXaaaXHwwHwwad',3)
//"ASDxAAAxhWWhWWAD"
具体使用方式在ec-do.js里面有说明
下面方法,如果在 demo 看到 'result:' 证明此函数是拥有返回值的函数,否则函数就没有返回值
ecDo.trim(str,type)
description-去除字符串的空格
param {String} str-待处理的字符串
param {Int} type-去除空格的形式(1-所有空格 2-前后空格 3-前空格 4-后空格,不传返回原字符串)
ecDo.trim(' 1235asd',1)
result:'1235asd'
ecDo.changeCase(str,type)
description-大小写转换
param {String} str-待处理的字符串
param {Int} type-转换的方式(1-首字母大写,2-首字母小写,3-大小写转换,4-全部大写,5-全部小写,不传返回原字符串)
ecDo.changeCase('asdasd',1)
result:'Asdasd'
ecDo.repeatStr(str,count)
description-字符串循环复制
param {String} str-待复制的字符串
param {Int} type-复制的次数
ecDo.repeatStr('123',3)
result:'123123123'
ecDo.replaceAll(str, AFindText, ARepText)
description-字符串替换
param {String} str-待处理的字符串
param {String} AFindText-要替换的字符或者正则表达式(不要写g)
param {String} ARepText-替换成什么
ecDo.replaceAll('这里是上海,中国第三大城市,广东省省会,简称穗,','上海','广州')
result:"这里是广州,中国第三大城市,广东省省会,简称穗,"
ecDo.replaceStr(str, regArr, type, ARepText)
description-字符替换*
param {String} str-待处理的字符串
param {Array} regArr-数据格式
param {Int} type-替换方式,(0-前面 1-后面)
param {String} ARepText-替换的字符,默认是‘*’
ecDo.replaceStr('18819322663',[3,5,3],0)
result:"188*****663"
ecDo.replaceStr('asdasdasdaa',[3,5,3],1)
result:***asdas***
ecDo.replaceStr('1asd88465asdwqe3',[5],0)
result:*****8465asdwqe3
ecDo.replaceStr('1asd88465asdwqe3',[5],1,'+')
result:"1asd88465as+++++"
ecDo.checkType(str, type)
description-检测字符串
param {String} str-待处理的字符串
param {String} type-数据格式(email,phone,tel,number,english,text,chinese,lower,upper)
ecDo.checkType('165226226326','phone')
result:false
ecDo.checkPwd(str)
description-检测密码强度
param {String} str-待检测的字符串
ecDo.checkPwd('12asdASAD')
result:result:3(强度等级为3,大写+1,小写+1,数字+1,'-','.','_'任意一字符+1,长度小于6等级为0)
ecDo.randomWord(count)
description-随机码
param {int} count-取值范围2-36
ecDo.randomWord(10)
result:"2584316588472575"
ecDo.randomWord(14)
result:"9b405070dd00122640c192caab84537"
ecDo.randomWord(36)
result:"83vhdx10rmjkyb9"
ecDo.countStr(str, strSplit)
description-检测字符串的出现次数
param {String} str-待处理的字符串
param {String} strSplit-待检测的字符串
var strTest='sad44654blog5a1sd67as9dablog4s5d16zxc4sdweasjkblogwqepaskdkblogahseiuadbhjcibloguyeajzxkcabloguyiwezxc967'
ecDo.countStr(strTest,'blog')
result:6
ecDo.filterStr(str, type, restr, spstr)
description-过滤字符串
param {String} str-待处理的字符串
param {String} type-过滤的类型(special-特殊字符,html-html标签,emjoy-emjoy表情,word-小写字母,WORD-大写字母,number-数字,chinese-中文。多种类型用','隔开。)
param {String} restr-替换成的字符,默认''
param {String} spstr-保留的特殊字符
ecDo.filterStr('asdasdaasd464132156','number')
result:"asdasdaasd"
var str='asd 654a大蠢sasdasdASDQWEXZC6d5#%^*^&*^%^&*$\\"\'#@!()*/-())_\'":"{}?<div></div><img src=""/>啊实打实大蠢猪自行车这些课程';
//过滤字符串的html标签,大写字母,中文,特殊字符。全部替换成*。但是特殊字符'%'和'?'可以保留,其他特殊字符全部被替换成*
ecDo.filterStr(str,'html,WORD,chinese,special','*','%?')
result:"asd 654a**sasdasd*********6d5#%^*^&*^%^&*$\"'#@!()*/-())_'":"{}?*****************"
ecDo.formatText(str, size, delimiter)
description-格式化处理字符串
param {String} str-待处理的字符串
param {Int} size-间隔
param {String} delimiter-间隔符,默认','
ecDo.formatText('1234asda567asd890')
result:"12,34a,sda,567,asd,890"
ecDo.formatText('1234asda567asd890',4,' ')
result:"1 234a sda5 67as d890"
ecDo.formatText('1234asda567asd890',4,'-')
result:"1-234a-sda5-67as-d890"
ecDo.formatText(str, splitType)
description-找出最长单词
param {String} str-字符串
param {splitType} size-间隔符,默认' '
ecDo.longestWord('Find the Longest word in a String')
result: {el: "Longest", max: 7}
ecDo.longestWord('Find|the|Longest|word|in|a|String','|')
result: {el: "Longest", max: 7}
ecDo.titleCaseUp(str, splitType)
description-句中单词首字母大写
param {String} str
param {splitType} size-间隔符,默认' '
ecDo.titleCaseUp('this is a title')
result: "This Is A Title"
ecDo.titleCaseUp('this is a title','|')
result: "This Is A Title"
ecDo.removeRepeatArray(arr)
description-数组去重
param {Array} arr-待去重数组
ecDo.removeRepeatArray([1,2,3,4,2,1,2,3,4,5])
result: [1, 2, 3, 4, 5]
ecDo.upsetArr(arr)
description-数组顺序打乱
param {Array} arr-待打乱数组
ecDo.upsetArr([1,2,3,4,5,6,7,8,9,0])
result: [7, 1, 3, 2, 4, 6, 8, 9, 0, 5]
ecDo.maxArr(arr)
description-获取数组最大值
param {Array} arr-待处理数组
ecDo.maxArr([1,2,3,4,5,6,7,8,9,0])
result: 9
ecDo.minArr(arr)
description-获取数组最小值
param {Array} arr-待处理数组
ecDo.minArr([1,2,3,4,5,6,7,8,9,0])
result: 0
ecDo.sumArr(arr)
description-数组求和
param {Array} arr-待处理数组
ecDo.sumArr([1,2,3,4,5,6,7,8,9,0])
result: 45
ecDo.covArr(arr)
description-数组求和
param {Array} arr-待处理数组
ecDo.covArr([1,2,3,4,5,6,7,8,9,0])
result: 4.5
ecDo.randomOne(arr)
description-从数组中随机获取一个元素
param {Array} arr-待处理数组
ecDo.randomOne(['a','b','c','d','e'])
result: "c"
ecDo.getEleCount(obj, ele)
description-获取数组(字符串)一个元素出现的次数
param {Array String} obj-待处理数组(字符串) param {String} ele-要匹配的元素
ecDo.getEleCount('asd56+asdasdwqe','a')
result:3
ecDo.getEleCount([1,2,3,4,5,66,77,22,55,22],22)
result:2
ecDo.getCount(arr, rank, ranktype)
description-获取数组(字符串)所有元素的出现次数
param {Array String} obj-待处理数组(字符串) param {Int} rank-返回长度,默认为返回所有, param {Int} ranktype-排序方式(按照出现此处) 默认降序,0-降序 1-升序
//返回所有情况
ecDo.getCount([1,2,3,1,2,5,2,4,1,2,6,2,1,3,2])
result:[{"el":"2","count":6},{"el":"1","count":4},{"el":"3","count":2},{"el":"4","count":1},{"el":"5","count":1},{"el":"6","count":1}]
//传参(rank=3),只返回出现次数排序前三的
ecDo.getCount([1,2,3,1,2,5,2,4,1,2,6,2,1,3,2],3)
result:[{"el":"2","count":6},{"el":"1","count":4},{"el":"3","count":2}]
//传参(ranktype=1,rank=null),升序返回所有元素出现次数
ecDo.getCount([1,2,3,1,2,5,2,4,1,2,6,2,1,3,2],null,1)
//result:[{"el":"6","count":1},{"el":"5","count":1},{"el":"4","count":1},{"el":"3","count":2},{"el":"1","count":4},{"el":"2","count":6}]
//传参(rank=3,ranktype=1),只返回出现次数排序(升序)前三的
getCount([1,2,3,1,2,5,2,4,1,2,6,2,1,3,2],3,1)
result:[{"el":"6","count":1},{"el":"5","count":1},{"el":"4","count":1}]
ecDo.getEleCount(obj, ele)
description-得到n1-n2下标的数组
param {Array} obj-待处理数组 param {int} n1-开始下标 param {int} n2-结束下标(不能比n1小)
ecDo.getArrayNum([0,1,2,3,4,5,6,7,8,9],5,9)
result:[5, 6, 7, 8, 9]
ecDo.getArrayNum([0,1,2,3,4,5,6,7,8,9],2)
//不传第二个参数,默认返回从n1到数组结束的元素
result:[2, 3, 4, 5, 6, 7, 8, 9]
ecDo.removeArrayForValue(arr, val, type)
description-删除值为'val'的数组元素
param {Array} obj-待处理数组 param {Sting} val-要匹配的字符 param {Sting} type-匹配模式(%)
//带有'test'的都删除
ecDo.removeArrayForValue(['test','test1','test2','test','aaa'],'test','%')
result:["aaa"]
//数组元素的值全等于'test'才被删除
ecDo.removeArrayForValue(['test','test1','test2','test','aaa'],'test')
result:["test1", "test2", "aaa"]
ecDo.getOptionArray(arr, keys)
description-获取对象数组某些项
param {Array} obj-待处理数组 param {Sting} keys-要获取的值的属性,多个属性用','分割
var arr=[{a:1,b:2,c:9},{a:2,b:3,c:5},{a:5,b:9},{a:4,b:2,c:5},{a:4,b:5,c:7}]
ecDo.getOptionArray(arr,'a')
result: [1, 2, 5, 4, 4]
ecDo.getOptionArray(arr,'a,c')
result:[{a: 1, c: 9},{a: 2, c: 5},{a: 5, c: undefined},{a: 4, c: 5},{a: 4, c: 7}]
ecDo.filterOptionArray(arr, keys)
description-过滤对象数组某些项
param {Array} arr-待处理数组 param {Sting} keys-要过滤的值的属性,多个属性用','分割
var arr=[{a:1,b:2,c:9},{a:2,b:3,c:5},{a:5,b:9},{a:4,b:2,c:5},{a:4,b:5,c:7}]
ecDo.filterOptionArray(arr,'a')
result: [1, 2, 5, 4, 4]
ecDo.filterOptionArray(arr,'a,c')
result:[{b: 2},{b: 3},{b: 9},{b: 2},{b: 5}]
ecDo.arraySort(arr, sortText)
description-对象数组的排序
param {Array} arr-待处理数组 param {Sting} sortText-排序字段,多个字段用','分割
var arr=[{a:1,b:2,c:9},{a:2,b:3,c:5},{a:5,b:9},{a:4,b:2,c:5},{a:4,b:5,c:7}]
//a是第一排序条件,b是第二排序条件
ecDo.arraySort(arr,'a,b')
result:[{"a":1,"b":2,"c":9},{"a":2,"b":3,"c":5},{"a":4,"b":2,"c":5},{"a":4,"b":5,"c":7},{"a":5,"b":9}]
ecDo.steamroller(arr)
description-数组扁平化
param {Array} arr-待处理数组
ecDo.steamroller([1,2,[4,5,[1,23]]])
result:[1, 2, 4, 5, 1, 23]
ecDo.getFontSize(_client)
description-适配rem
param {Int} _client-设计图宽度
ecDo.getFontSize(750)
ecDo.getEndTime(endTime)
description-适配rem
param {String} endTime-结束时间(需要正确的时间格式)
ecDo.getEndTime('2017/11/22 16:0:0')
//目前时间是2017.11.6 17.14.55
result:{
d:15,
h:22,
m:46,
s:43
}
ecDo.getEndTime(endTime)
description-生成随机颜色
ecDo.randomColor()
result:"#491d82"
ecDo.randomColor()
result:"#3e0683"
ecDo.randomNumber(n1, n2)
description-随机返回一个范围的数字
param {Int} n1-最小值
param {Int} n2-最大值
//返回5-10的随机整数,包括5,10
ecDo.randomNumber(5,10)
result:6
//返回0-10的随机整数,包括0,10
ecDo.randomNumber(10)
result:7
ecDo.setUrlPrmt(obj)
description-设置url参数
param {Object} obj-需要设置的参数
ecDo.setUrlPrmt({'a':1,'b':2})
result:a=1&b=2
ecDo.getUrlPrmt(url)
description-获取url参数
param {String} url-超链接
ecDo.getUrlPrmt('github.com?draftId=122000011938')
result:{draftId: "122000011938"}
ecDo.upDigit(n)
description-现金额大写转换函数
param {number} n-金额数目
ecDo.upDigit(10.5)
result:"人民币壹拾元伍角"
ecDo.upDigit(168752632)
result:"人民币壹亿陆仟捌佰柒拾伍万贰仟陆佰叁拾贰元整"
ecDoupDigit(1682)
result:"人民币壹仟陆佰捌拾贰元整"
ecDo/upDigit(-1693)
result:"欠人民币壹仟陆佰玖拾叁元整"
ecDo.filterParams(obj)
description-过滤对象里面值为null或者underfind的的属性underfind的属性
param {Object} obj-待处理对象
ecDo.filterParams({a:"",b:null,c:"010",d:123})
result:{c: "010", d: 123}
ecDo.istype(o, type)
description-数据类型判断
param {Array|Object|String|Function|Number|Boolean|Undefined|Null|HTML} o-待处理的对象 param {String} type-类型字符串
ecDo.istype([],'array')
result:true
ecDo.istype([])
result:'[object Array]'
ecDo.browserInfo(type)
description-手机类型判断 param {String} type-类型字符串(android|iphone|ipad|weixin)
ecDo.browserInfo('android')
result:是安卓就返回true,否则就false
ecDo.browserInfo()
result:返回手机浏览器的信息
ecDo.delayFn(fn, delay, mustDelay)
description-函数节流 param {String} fn-执行的函数 param {Number} delay-间隔时间 param {Number} mustDelay-最大间隔时间
var count=0;
function fn1(){
count++;
console.log(count)
}
//每100ms连续触发的调用,后一个调用会把前一个调用的等待处理掉,但每隔200ms至少执行一次
document.onmousemove=delayFn(fn1,100,200)
ecDo.setCookie(name, value, iDay)
description-设置cookie
param {String} name-cookie名 param {String} value-cookie值 param {Int} iDay-时间(天数)
ecDo.setCookie('test', 'testcookie', 2)
ecDo.getCookie(name)
description-获取cookie
param {String} name-cookie名
ecDo.getCookie('test')
ecDo.removeCookie(name)
description-删除cookie
param {String} name-cookie名
ecDo.removeCookie('test')
ecDo.hasClass(obj, classStr)
description-检测对象是否有哪个类名
param {Object} obj-Dom对象 param {String} classStr-class名
ecDo.classStr(obj,'test')
result:true|false
ecDo.addClass(obj, classStr)
description-添加类名
param {Object} obj-Dom对象 param {String} classStr-class名
ecDo.addClass(obj,'test')
ecDo.removeClass(obj, classStr)
description-添加类名
param {Object} obj-Dom对象 param {String} classStr-class名
ecDo.removeClass(obj,'test')
ecDo.replaceClass(obj, newName, oldName)
description-替换类名
param {Object} obj-Dom对象 param {String} newName-被替换的类名 param {String} oldName-替换的类名
ecDo.replaceClass(obj,'test','afterClass')
ecDo.siblings(obj, opt)
description-获取兄弟节点
param {Object} obj-Dom对象 param {String} opt-过滤条件
ecDo.siblings(obj,'#id')
result:符合条件的Dom对象
ecDo.css(obj,json)
description-设置样式
param {Object} obj-Dom对象 param {Object} json-样式名
ecDo.css(obj,{'width':'300px','height':'300px'})
ecDo.html(obj)
ecDo.html(obj,str)
description-设置或者获取对象的所有内容
param {Object} obj-Dom对象 param {String} str-html内容
ecDo.html(obj)
result:innerHTML
ecDo.html(obj,'<div>1111</div>')
ecDo.text(obj)
ecDo.text(obj,str)
description-设置或者获取对象的文本
param {Object} obj-Dom对象 param {String} str-内容(html标签将会被过滤)
ecDo.text(obj)
result:innerHTML(过滤html标签)
ecDo.text(obj,'1230.312asd')
ecDo.show(obj)
description-显示对象
param {Object} obj-Dom对象
ecDo.show(obj)
ecDo.hide(obj)
description-隐藏对象
param {Object} obj-Dom对象
ecDo.hide(obj)
ecDo.ajax(obj)
description-ajax封装参数
param {Object} 对象参数
- @param {string}obj.type http连接的方式,包括POST和GET两种方式
- @param {string}obj.url 发送请求的url
- @param {boolean}obj.async 是否为异步请求,true为异步的,false为同步的
- @param {object}obj.data 发送的参数,格式为对象类型
- @param {function}obj.success ajax发送并接收成功调用的回调函数
- @param {function}obj.error ajax发送失败或者接收失败调用的回调函数
ecDo.ajax({
type:'get',
url:'xxx',
data:{
id:'111'
},
success:function(res){
console.log(res)
}
})
ecDo.aftLoadImg(obj, url, errorUrl,cb)
description-图片没加载出来时用一张图片代替
param {Object} obj-Dom对象 param {String} url-图片的url param {String} errorUrl-出错的图片的url param {Function} cb-回调函数,参数为obj
ecDo.aftLoadImg(oImgLoad[i], oImgLoad[i].dataset.src, _errorUrl,function(o){console.log(o)});
ecDo.loadImg(className, num, errorUrl)
description-图片滚动懒加载
param {String} className-遍历Dom带有的类名 param {String} num-图片的url param {String} errorUrl-出错的图片的url
//比如,一张图片距离文档顶部3000,num参数设置200,那么在页面滚动到2800的时候,图片加载。不传num参数就滚动,num默认是0,页面滚动到3000就加载
//html代码
//<p><img data-src="lawyerOtherImg.jpg" class="load-img" width='528' height='304' /></p>
//<p><img data-src="lawyerOtherImg.jpg" class="load-img" width='528' height='304' /></p>
//<p><img data-src="lawyerOtherImg.jpg" class="load-img" width='528' height='304' /></p>....
//data-src储存src的数据,到需要加载的时候把data-src的值赋值给src属性,图片就会加载。
//详细可以查看testLoadImg.html
window.onload = function() {
ecDo.loadImg('load-img',100);
window.onscroll = function() {
ecDo. loadImg('load-img',100);
}
}
ecDo.createKeyExp(strArr)
description-创建正则字符
param {Array} strArr-要创建的关键字
ecDo.createKeyExp(['守候','开'])
result:(前端|过来)
ecDo.findKey(str, key, el)
description-关键字加标签(高亮)
param {String} str-待处理的字符串 param {String} key-关键字,多个关键字','分割 param {String} el-要添加的元素,html标签元素 默认span
ecDo.findKey('守侯我oaks接到了来自下次你离开快乐吉祥留在开城侯','守侯 开')
result:"<span>守侯</span>我oaks接到了来自下次你离<span>开</span>快乐吉祥留在<span>开</span>城侯"
ecDo.findKey('守侯我oaks接到了来自下次你离开快乐吉祥留在开城侯','守侯 开','i')
result:"<i>守侯</i>我oaks接到了来自下次你离<i>开</i>快乐吉祥留在<i>开</i>城侯"
MIT