获取当前时间
//获取当前时间,格式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;
}
正则表达式
Email地址:^\w+([-+.]\w+)@\w+([-.]\w+).\w+([-.]\w+)*$
域名:[a-zA-Z0-9][-a-zA-Z0-9]{0,62}(/.[a-zA-Z0-9][-a-zA-Z0-9]{0,62})+/.?
InternetURL:[a-zA-z]+://[^\s]* 或 ^http://([\w-]+.)+[\w-]+(/[\w-./?%&=]*)?$
手机号码:^(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}$
电话号码(“XXX-XXXXXXX”、”XXXX-XXXXXXXX”、”XXX-XXXXXXX”、”XXX-XXXXXXXX”、”XXXXXXX”和”XXXXXXXX):^((\d{3,4}-)|\d{3.4}-)?\d{7,8}$
国内电话号码(0511-4405222、021-87888822):\d{3}-\d{8}|\d{4}-\d{7}
身份证号(15位、18位数字):^\d{15}|\d{18}$
短身份证号码(数字、字母x结尾):^([0-9]){7,18}(x|X)? 或\d8,18|[0−9x]8,18|[0−9X]8,18? 或 \d 8 , 18 | [ 0 − 9 x ] 8 , 18 | [ 0 − 9 X ] 8 , 18 ?
帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
密码(以字母开头,长度在6~18之间,只能包含字母、数字和下划线):^[a-zA-Z]\w{5,17}$
强密码(必须包含大小写字母和数字的组合,不能使用特殊字符,长度在8-10之间):^(?=.\d)(?=.[a-z])(?=.*[A-Z]).{8,10}$
日期格式:^\d{4}-\d{1,2}-\d{1,2}
一年的12个月(01~09和1~12):^(0?[1-9]|1[0-2])$
一个月的31天(01~09和1~31):^((0?[1-9])|((1|2)[0-9])|30|31)$
钱的输入格式:
1.有四种钱的表示形式我们可以接受:”10000.00” 和 “10,000.00”, 和没有 “分” 的 “10000” 和 “10,000”:^[1-9][0-9]*$
2.这表示任意一个不以0开头的数字,但是,这也意味着一个字符”0”不通过,所以我们采用下面的形式:^(0|[1-9][0-9]*)$
3.一个0或者一个不以0开头的数字.我们还可以允许开头有一个负号:^(0|-?[1-9][0-9]*)$
4.这表示一个0或者一个可能为负的开头不为0的数字.让用户以0开头好了.把负号的也去掉,因为钱总不能是负的吧.下面我们要加的是说明可能的小数部分:^[0-9]+(.[0-9]+)?$
5.必须说明的是,小数点后面至少应该有1位数,所以”10.”是不通过的,但是 “10” 和 “10.2” 是通过的:^[0-9]+(.[0-9]{2})?$
6.这样我们规定小数点后面必须有两位,如果你认为太苛刻了,可以这样:^[0-9]+(.[0-9]{1,2})?$
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})?$
备注:这就是最终结果了,别忘了”+”可以用”*”替代如果你觉得空字符串也可以接受的话(奇怪,为什么?)最后,别忘了在用函数时去掉去掉那个反斜杠,一般的错误都在这里
xml文件:^([a-zA-Z]+-?)+[a-zA-Z0-9]+\.[x|X][m|M][l|L]$
中文字符的正则表达式:[\u4e00-\u9fa5]
双字节字符:[^\x00-\xff] (包括汉字在内,可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1))
空白行的正则表达式:\n\s*\r (可以用来删除空白行)
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];
}
}