问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

谁能介绍下JS开发的几款常用工具

发布网友 发布时间:2022-05-12 14:23

我来回答

3个回答

懂视网 时间:2022-05-15 09:56

本篇文章介绍的内容是关于js 常用的工具方法,现在分享给大家,有需要的朋友可以参考一下

1、cookie 操作

// setCookie()
// @About 设置cookie 默认一个月失效
function setCookie(name, value) {
 var Days = 30;
 var exp = new Date();
 exp.setTime(exp.getTime() + Days * 24 * 60 * 60 * 1000);
 document.cookie = name + "=" + escape(value) + ";expires=" + exp.toGMTString();
}


// getCookie()
// @About 获取cookie
function getCookie(name) {
 var arr = document.cookie.match(new RegExp("(^| )" + name + "=([^;]*)(;|$)"));
 if (arr != null) {
 return (arr[2]);
 } else {
 return "";
 }
}


// delCookie()
// @About 删除cookie
function delCookie(name) {
 var exp = new Date();
 exp.setTime(exp.getTime() - 1);
 var cval = getCookie(name);
 if (cval != null) {
 document.cookie = name + "=" + cval + ";expires=" + exp.toGMTString();
 }
}

2、随机数

//随机返回一个范围的数字。参数是两个的时候,返回传入的两个参数的区间的随机函数;参数是一个的时候,返回0到这个数的随机函数;参数是零个的时候,返回0到255区间的整数,大家可以根据自己的需要进行扩展

function randomNumber(n1,n2){
 if(arguments.length===2){
 return Math.round(n1+Math.random()*(n2-n1));
 }
 
 else if(arguments.length===1){
 return Math.round(Math.random()*n1)
 }
 //
 //
 else{
 return Math.round(Math.random()*255)
 } 
}


randomNumber(5,10) // 返回5-10的随机整数,包括5,10
randomNumber(10) // 返回0-10的随机整数,包括0,10
randomNumber() // 返回0-255的随机整数,包括0,255

3、

到某一个时间的倒计时,传入的参数以 (YYYY/MM/DD H:mm:ss)

function getEndTime(endTime){
 var startDate=new Date(); //开始时间,当前时间
 var endDate=new Date(endTime); //结束时间,需传入时间参数
 var t=endDate.getTime()-startDate.getTime(); //时间差的毫秒数
 var d=0,h=0,m=0,s=0;
 if(t>=0){
 d=Math.floor(t/1000/3600/24);
 h=Math.floor(t/1000/60/60%24);
 m=Math.floor(t/1000/60%60);
 s=Math.floor(t/1000%60);
 } 
 return "剩余时间"+d+"天 "+h+"小时 "+m+" 分钟"+s+" 秒";
}


getEndTime('2018/8/8 8:0:0') // "剩余时间172天 12小时 10 分钟47 秒"

4,清除对象中值为空的属性

function filterParams(obj){
 let _newPar = {};
 for (let key in obj) {
 if ((obj[key] !== 0 && obj[key]) && obj[key].toString().replace(/(^s*)|(s*$)/g, '') !== '') {
  _newPar[key] = obj[key];
 }
 }
 return _newPar;
}


filterParams({a:0, b:1, c:"010", d:null, e:undefined,f:false}) 
// 当值等于0,null,undefined的时候,就会被过滤

这里涉及到了一个知识点:&&和||运算符的先后顺序,我相信大部分的朋友都知道,我就简单提一下:


return a && b || c ,
根据a来判断返回值,a 是 false 则肯定返回 c;如果 b , c 都是 true ,那么我们就可以根据 a 来决定b 还是 c ,如果 a 是 false 则返回 c,如果a是true 则返回 b。


var a = 3 && 0 || 2; //2
return a || b && c


根据优先级相当于先算 b && c ,然后和a 相 或;如果a是true,则返回a,不论是b或c,如果a是false,则如果b是false,返回b,如果b是true,返回c;


var b = 3 || 0 && 2; // 3
var c= 0 || 2 && 3; // 3

更多操作大家可以参考JS运算符&&和|| 及其优先级。



5,获取,设置url参数,url 参数就是其中 ? 后面的参数

function getUrlPrmt(url) {
 url = url ? url : window.location.href; let _pa = url.substring(url.indexOf('?') + 1), _arrS = _pa.split('&'), _rs = {}; for (let i = 0, _len = _arrS.length; i < _len; i++) { let pos = _arrS[i].indexOf('='); if (pos == -1) {  continue;
 } let name = _arrS[i].substring(0, pos), value = window.decodeURIComponent(_arrS[i].substring(pos + 1));
 _rs[name] = value;
 } return _rs;
}





这里是设置url参数的函数,如果对象中有nullundefined,则会自动过滤。

function setUrlPrmt(obj) { let _rs = []; for (let p in obj) { if (obj[p] != null && obj[p] != '') {
  _rs.push(p + '=' + obj[p])
 }
 } return _rs.join('&');
}

setUrlPrmt({a:'0', b:1, c:"010", d:null, e:undefined,f:false}) // "a=0&b=1&c=010"




6,获取文件后缀名的方法,参数的file_name,即传进来的文件;返回值是扩展名、后缀名的位置下标以及文件名

function getSuffix(file_name) { var result = /[^.]+$/.exec(file_name); return result;
}

getSuffix('1234.png') // ["png", index: 5, input: "1234.png"]getSuffix('1231344.file'); // ["file", index: 8, input: "1231344.file"]

7,查看浏览器是否支持某一个css3的属性,不如firefox浏览器中是不支持-webkit-开头的属性的

function supportCss3(style) { var prefix = ['webkit', 'Moz', 'ms', 'o'],
 i,
 humpString = [],
 htmlStyle = document.documentElement.style,
 _toHumb = function(string) {  return string.replace(/-(w)/g, function($0, $1) {  return $1.toUpperCase();
  });
 }; for (i in prefix)
 humpString.push(_toHumb(prefix[i] + '-' + style));
 humpString.push(_toHumb(style)); for (i in humpString) if (humpString[i] in htmlStyle) return true; return false;
}




这个是chorme中的结果:





这个是firefox中的结果:







8,怎么判断一个对象是不是数组类型?


我们采取最常用的方法:根据对象的class属性(类属性),跨原型链调用toString()方法。

function _getClass(o){ return Object.prototype.toString.call(o).slice(8,-1);
}

_getClass(new Date()); // Date_getClass('maolei'); // String

此外如果你想要了解更多的判断是不是数组类型的方法,可参考:判断一个对象是不是数组类型


9,js的排序算法,这里就使用最简单的冒泡排序,关于js的选择排序算法,大家可以参考js十大排序算法详解

function bubbleSort(arr) { var len = arr.length; for (var i = 0; i < len; i++) { for (var j = 0; j < len - 1 - i; j++) {  if (arr[j] > arr[j+1]) { //相邻元素两两对比
  var temp = arr[j+1]; //元素交换
  arr[j+1] = arr[j];
  arr[j] = temp;
  }
 }
 } return arr;
}var arr=[3,44,38,5,47,15,36,26,27,2,46,4,19,50,48];
bubbleSort(arr);//[2, 3, 4, 5, 15, 19, 26, 27, 36, 38, 44, 46, 47, 48, 50] ;

10,最后是我在一个前端大神芋头君live前端笔试题十讲中听到的一个题目:实现一个最简单的模板引擎,感觉很有趣,就直接以这道题作为结尾吧

render('我是{{name}},年龄{{age}},性别{{sex}}',{
 name:'姓名',
 age:18,
 sex:'女'})

我们可以用正则表达式和replace解决:

var render = function(tpl,data){ return tpl.replace(/{{(.+?)}}/g,function(m,m1){ return data[m1]
 })
}

render('我是{{name}},年龄{{age}},性别{{sex}}',{ name:'姓名', age:18,sex:'女',
}) 
// "我是姓名,年龄18,性别女"



热心网友 时间:2022-05-15 07:04

浏览器,比如chrome,它很强大,可以打断点单步调试,可以看html结构,可以调css样式,可以模拟伪类事件,可以模拟不同视口的设备。

编译器推荐Atom , Sublime text3 。

ps: 既然是新手 ,就先别用IDE,要自己去敲,多敲才能记住一些东西!
pps: 要记住一些快捷键,便于提高效率。
gulp / webpack + babel自动化工具,效率高!

热心网友 时间:2022-05-15 08:22

Notepad++、sublime、
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
陈八两面馆的什么面最好吃? 杭州湾跨海大桥可以骑行吗 杭州湾跨海大桥上能骑车吗? ...不知道可不可以骑自行车,又需要做哪些准备,谢谢各位资深人士了... 激光祛痘坑的效果如何? 口述:3个闺密分享1个“软饭男” 骚气文案暗示-推荐65句 三个男人怎么晒朋友圈 任钊的介绍 请问德阳青依江路口到德阳中级人民法院坐几路公交车 手机号和怎么解绑 如何解绑绑定的手机号? 凯缘春蓝莓酒的好处及效用,谁了解过吗? 暗黑魔法师崛起有了魂石就是选不了魂法师 完美国际一转没有转生石。怎么弄啊?接不到任务。转生大师也买不到 全民无双庞统怎么样 庞统将魂石获取攻略详解 请问制造初级集魂石需要什么材料,各多少 最终幻想14新生魂石怎么获得 发展中国家的金融自由化失败案例有哪些 民生银行定向增发获得200亿的融资,请问对股票的影响深度如何? 有谁能提供一份某公司的融资决策的操作案例(具体到某一公司),最好包含直接融资和间接融资 近年直接融资比重上升的原因~要有案例哦! 各举两个直接金融和间接金融的例子,说明我国金融市场缺乏效率。 阿里巴巴从国际资本市场上直接融资的例子 能提供一个能够阐述关于直接融资以下三个优点的真实例子吗,最好是国外... 小米6微信聊天界面的树水印如何删除? 聊天背景上水印显示在哪里? 怎么知道家里空调关没关? 有谁知道那种小孩子玩的那种手拿的很细的那种一点起来拿手里挥挥的烟花呀叫什么 一个绿色的细细的长长的,像绳子一样的烟花,一点着就噼哩叭啦的响,溅出很多小火花、求名称、图片也行 javascript做前端开发用什么软件好 js脚本开发用什么工具 javascript在什么软件开发 误删微信好友没有电话,,怎样添加回来- 问一问 删除微信好友不记得怎么加回来? 手机初始密码是什么 用两样什么就可以做橡皮泥了 哪个品牌的矿泉水好喝,VOSS怎么样? 求助酷比H1S手机的刷机教程?可以刷安卓5.0吗? 酷比h1s系统更新失败怎么办手机开不了机了,显示系统无命令 酷比h1s怎么回复出厂设置啊 酷比手机怎么用手机来刷机 酷比手机A720的rec,怎么刷进去,给个工具刷进去,,还有最新版的rom,,,不用告诉我去官网论 想买一个手机酷比h1s,999软妹币,用来刷贴吧,qq,爱奇艺,质量怎么样值得购买吗? 信用卡逾期能做火车吗 有没有用酷比H1S手机的啊?我记得买的时候说有隔空操作的啊?网上查也有,可是为什么不知道怎么打开这 酷比手机h1s钢化玻璃屏烂了有换吗?价格多少? CAD2012安装不上, 欠信用卡可以坐火车吗 酷比h1s手机接电话怎么会黑屏