常用代码

获取当前时间

//获取当前时间,格式YYYY-MM-DD hh-mm-ss
function timestampToTime (timestamp)
{
    if(timestamp){
      var date = new Date(timestamp * 1000);//时间戳为10位需*1000,时间戳为13位的话不需乘1000
      Y = date.getFullYear() + '-';
      M = (date.getMonth()+1 < 10 ? '0'+(date.getMonth()+1) : date.getMonth()+1) + '-';
      D = (date.getDate()<10?'0'+date.getDate() : date.getDate())+' ';
      h = (date.getHours()<10?'0'+date.getHours() : date.getHours()) + ':';
      m = (date.getMinutes()<10?'0'+date.getMinutes() : date.getMinutes())  + ':';
      s = (date.getSeconds()<10?'0'+date.getSeconds() : date.getSeconds());
      return Y+M+D+h+m+s;
    }else{
      return '';
    }
  }
}

千分位

function Convert(money) 
{ 
var s = money; //获取小数型数据 
s += ""; 
if (s.indexOf(".") == -1) s += ".00"; //如果没有小数点,在后面补个小数点和00 
if (/\.\d$/.test(s)) s += "0"; //正则判断 
while (/\d{4}(\.|,)/.test(s)) //符合条件则进行替换 
s = s.replace(/(\d)(\d{3}(\.|,))/, "$1,$2"); //每隔3位添加一个 
return s; 
} 

正则表达式

  1. Email地址:^\w+([-+.]\w+)@\w+([-.]\w+).\w+([-.]\w+)*$

  2. 域名:[a-zA-Z0-9][-a-zA-Z0-9]{0,62}(/.[a-zA-Z0-9][-a-zA-Z0-9]{0,62})+/.?

  3. InternetURL:[a-zA-z]+://[^\s]* 或 ^http://([\w-]+.)+[\w-]+(/[\w-./?%&=]*)?$

  4. 手机号码:^(13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|18[0|1|2|3|5|6|7|8|9])\d{8}$

  5. 电话号码(“XXX-XXXXXXX”、”XXXX-XXXXXXXX”、”XXX-XXXXXXX”、”XXX-XXXXXXXX”、”XXXXXXX”和”XXXXXXXX):^((\d{3,4}-)|\d{3.4}-)?\d{7,8}$

  6. 国内电话号码(0511-4405222、021-87888822):\d{3}-\d{8}|\d{4}-\d{7}

  7. 身份证号(15位、18位数字):^\d{15}|\d{18}$

  8. 短身份证号码(数字、字母x结尾):^([0-9]){7,18}(x|X)? \d8,18|[09x]8,18|[09X]8,18? 或 \d 8 , 18 | [ 0 − 9 x ] 8 , 18 | [ 0 − 9 X ] 8 , 18 ?

  9. 帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$

  10. 密码(以字母开头,长度在6~18之间,只能包含字母、数字和下划线):^[a-zA-Z]\w{5,17}$

  11. 强密码(必须包含大小写字母和数字的组合,不能使用特殊字符,长度在8-10之间):^(?=.\d)(?=.[a-z])(?=.*[A-Z]).{8,10}$

  12. 日期格式:^\d{4}-\d{1,2}-\d{1,2}

  13. 一年的12个月(01~09和1~12):^(0?[1-9]|1[0-2])$

  14. 一个月的31天(01~09和1~31):^((0?[1-9])|((1|2)[0-9])|30|31)$

  15. 钱的输入格式:

  16. 1.有四种钱的表示形式我们可以接受:”10000.00” 和 “10,000.00”, 和没有 “分” 的 “10000” 和 “10,000”:^[1-9][0-9]*$

  17. 2.这表示任意一个不以0开头的数字,但是,这也意味着一个字符”0”不通过,所以我们采用下面的形式:^(0|[1-9][0-9]*)$

  18. 3.一个0或者一个不以0开头的数字.我们还可以允许开头有一个负号:^(0|-?[1-9][0-9]*)$

  19. 4.这表示一个0或者一个可能为负的开头不为0的数字.让用户以0开头好了.把负号的也去掉,因为钱总不能是负的吧.下面我们要加的是说明可能的小数部分:^[0-9]+(.[0-9]+)?$

  20. 5.必须说明的是,小数点后面至少应该有1位数,所以”10.”是不通过的,但是 “10” 和 “10.2” 是通过的:^[0-9]+(.[0-9]{2})?$

  21. 6.这样我们规定小数点后面必须有两位,如果你认为太苛刻了,可以这样:^[0-9]+(.[0-9]{1,2})?$

  22. 7.这样就允许用户只写一位小数.下面我们该考虑数字中的逗号了,我们可以这样:^[0-9]{1,3}(,[0-9]{3})*(.[0-9]{1,2})?$

23 8.1到3个数字,后面跟着任意个 逗号+3个数字,逗号成为可选,而不是必须:^([0-9]+|[0-9]{1,3}(,[0-9]{3})*)(.[0-9]{1,2})?$

  1. 备注:这就是最终结果了,别忘了”+”可以用”*”替代如果你觉得空字符串也可以接受的话(奇怪,为什么?)最后,别忘了在用函数时去掉去掉那个反斜杠,一般的错误都在这里

  2. xml文件:^([a-zA-Z]+-?)+[a-zA-Z0-9]+\.[x|X][m|M][l|L]$

  3. 中文字符的正则表达式:[\u4e00-\u9fa5]

  4. 双字节字符:[^\x00-\xff] (包括汉字在内,可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1))

  5. 空白行的正则表达式:\n\s*\r (可以用来删除空白行)

  6. HTML标记的正则表达式:<(\S*?)[^>]>.?

常用的js工具函数

JS选取DOM元素的方法
注意:原生JS选取DOM元素比使用jQuery类库选取要快很多
1、通过ID选取元素
document.getElementById(‘myid’);
2、通过CLASS选取元素
document.getElementsByClassName(‘myclass’)[0];
3、通过标签选取元素
document.getElementsByTagName(‘mydiv’)[0];
4、通过NAME属性选取元素(常用于表单)
document.getElementsByName(‘myname’)[0];

JS修改CSS样式
document.getElementById(‘myid’).style.display = ‘none’;

JS修改CLASS属性
document.getElementById(‘myid’).className = ‘active’;

如果有多个CLASS属性,即用空格隔开////////
document.getElementById(‘myid’).className = ‘active div-1’;

移除该元素上的所有CLASS
document.getElementById(‘myid’).className = ”
注意:使用classList会优于使用className
document.getElementById(‘myid’).classList.item(0);//item为类名的索引
document.getElementById(‘myid’).classList.length;//只读属性
document.getElementById(‘myid’).classList.add(‘newClass’);//添加class
document.getElementById(‘myid’).classList.remove(‘newClass’);//移除class
document.getElementById(‘myid’).classList.toggle(‘newClass’);//切换,有则移除,没有则添加
document.getElementById(‘myid’).classList.contains(‘newClass’);//判断是否存在该class

页面属性

加入收藏夹
function AddFavorite(sURL, sTitle) {
  try {
    window.external.addFavorite(sURL, sTitle)
  } catch (e) {
  try {
    window.sidebar.addPanel(sTitle, sURL, “”)
  } catch (e) {
    alert(“加入收藏失败,请使用Ctrl+D进行添加”)
  }
  }
}
设为首页
function setHomepage(homeurl) {
  if (document.all) {
  document.body.style.behavior = ‘url(#default#homepage)’;
  document.body.setHomePage(homeurl)
  } else if (window.sidebar) {
    if (window.netscape) {
  try {
    netscape.security.PrivilegeManager.enablePrivilege(“UniversalXPConnect”)
  } catch (e) {
    alert(“该操作被浏览器拒绝,如果想启用该功能,请在地址栏内输入about:config,然后将项 signed.applets.codebase_principal_support 值该为true”);
  }
}
var prefs = Components.classes[‘@mozilla.org/preferences-service;1’].getService(Components.interfaces.nsIPrefBranch);
prefs.setCharPref(‘browser.startup.homepage’, homeurl)
}
}

跨浏览器绑定事件
function addEventSamp(obj, evt, fn) {
  if (!oTarget) { return; }
  if (obj.addEventListener) {
    obj.addEventListener(evt, fn, false);
  } else if (obj.attachEvent) {
    obj.attachEvent(‘on’ + evt, fn);
  } else {
    oTarget[“on” + sEvtType] = fn;
  }
}

跨浏览器删除事件
function delEvt(obj, evt, fn) {
  if (!obj) { return; }
  if (obj.addEventListener) {
    obj.addEventListener(evt, fn, false);
  } else if (oTarget.attachEvent) {
    obj.attachEvent(“on” + evt, fn);
  } else {
    obj[“on” + evt] = fn;
  }
}

判断是否移动设备访问
function isMobileUserAgent() {
  return (/iphone|ipod|android.*mobile|windows.*phone|blackberry.*mobile/i.test(window.navigator.userAgent.toLowerCase()));
}

获取页面高度
function getPageHeight() {
  var g = document, a = g.body, f = g.documentElement, d = g.compatMode == “BackCompat” ? a : g.documentElement;
  return Math.max(f.scrollHeight, a.scrollHeight, d.clientHeight);
}
获取页面宽度
function getPageWidth() {
  var g = document, a = g.body, f = g.documentElement, d = g.compatMode == “BackCompat” ? a : g.documentElement;
  return Math.max(f.scrollWidth, a.scrollWidth, d.clientWidth);
}

获取页面scrollLeft
function getPageScrollLeft() {
  var a = document;
  return a.documentElement.scrollLeft || a.body.scrollLeft;
}
获取页面滚动距离
function getScrollOffset(){
  if(window.pageXOffset){
    return{
      X : window.pageXOffset;
      Y : window.pageYOffset
    }
  }else{//IE8及以下
    return{
      X : document.body.scrollLeft+document.documentElement.scrollLeft;
      Y : document.body.scrollTop+document.documentElement.scrollTop;
    }
 }
}

获取窗体可见范围的宽与高
function getViewportOffset() {
  if(window.innerWidth){
    return{
      X : window.innerWidth;
      Y : window.innerHeight
      }
   }else{//IE8及以下
    if(document.compatMode == “BackCompat”){//如果是怪异模式、混杂模式
      return{
        X : document.body.clientWidth;
        Y : document.body.clientHeight;
       }
}else{
  return {
     X : document.documentElement.clientWidth;//标准模式
     Y : document.documentElement.clientHeight
    }
   }
  }
}

查看元素的几何尺寸
domEle.getBoundingClientRect();//6个值 left top right bottom width height 不是实时监控的

查看元素的视觉尺寸
div.offsetWidth
div.offsetHeight
div.offsetLeft //对于无定位的父集返回文档的坐标,对于有定位的父集返回相对最近有定位父集的坐标
div.offsetTop
div.offsetParent //返回最近的有定位的父集

返回一个元素在文档中的坐标
function getElmentPosition(div){
  if(div.offsetParent == body){
  return {
    X : div.offsetLeft;
    Y : div.offsetTop
    }
  }else{

  }
}

让滚动条滚动
scrollTo();//滚动到xxx
scrollBy();//累加滚动xxxx

行间样式-可以写入
div.style.width //必须写到css style里面,获取的都是style里的
div.style.cssFloat//浮动
window.getComputedStyle(div,null) //返回的计算样式都是计算过的,不存在相对单位,只读
window.getComputedStyle(div,null).width
window.getComputedStyle(div,”after”) //获取伪元素的样式表
ele.currentStyle//ie专用,获取显示显示样式,只读
ele.currentStyle.width

获取样式属性
function getStyle(elem,prop){
  if(window.getcomputedStyle){
    return window.getComputedStyle(elem,null)[prop];
  }else{
    return elem.currentStyle[prop];
  }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

liao_weiping

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值