您的位置:首页 > Web前端 > JavaScript

js中常用方法总结

2017-07-27 22:22 776 查看
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

补充:add和remove方法不允许链式操作,因为返回的都是undefined,其次,也不允许同时添加或删除多个class,可以自行扩展一下

[javascript] view
plain copy

DOMTokenList.prototype.adds = function(tokens){  

    tokens.split(' ').forEach(function(token){  

        this.add(token);  

    }).bind(this));  

    return this;  

};  

var clList = document.body.classList;  

clList.adds('a b c').toString();  

//a b c  

JS修改文本
document.getElementById('myid').innerHTML = '123';

JS创建元素并向其中追加文本
var newdiv = document.createElement('div');
var newtext = document.createTextNode('123');
newdiv.appendChild(newtext);
document.body.appendChild(newdiv);
同理:removeChild()移除节点,并返回节点
cloneNode()复制节点

insertBefore()插入节点(父节点内容的最前面)

注意:insertBefore()有两个参数,第一个是插入的节点,第二个是插入的位置

例子:

var list = document.getElementById('myList');

list.insertBefore(newItem,list.childNodes[1]);

//插入新节点newItem到list的第二个子节点

JS返回所有子节点对象childNodes
var mylist = document.getElementById('myid');
for(var i=0,i<mylist.childNodes.length;i++){
console.log(mylist.childNodes[i]);
}
firstChild返回第一个子节点
lastChild返回最后一个子节点
parentNode返回父节点对象
nextSibling返回下一个兄弟节点对象
previousSibling返回前一个兄弟节点对象
nodeName返回节点的HTML标记名称
验证是否为图片格式

复制代码 代码如下:

 function IsImgType(src) {

     var rFilter = /^(?:image\/bmp|image\/cis\-cod|image\/gif|image\/ief|image\/jpeg|image\/jpeg|image\/jpeg|image\/pipeg|image\/png|image\/svg\+xml|image\/tiff|image\/x\-cmu\-raster|image\/x\-cmx|image\/x\-icon|image\/x\-portable\-anymap|image\/x\-portable\-bitmap|image\/x\-portable\-graymap|image\/x\-portable\-pixmap|image\/x\-rgb|image\/x\-xbitmap|image\/x\-xpixmap|image\/x\-xwindowdump)$/i;

     var Filter = /(?:bmp|cis\-cod|gif|ief|jpeg|jpeg|jpeg|pipeg|png|svg\+xml|tiff|x\-cmu\-raster|x\-cmx|x\-icon|x\-portable\-anymap|x\-portable\-bitmap|x\-portable\-graymap|x\-portable\-pixmap|x\-rgb|x\-xbitmap|x\-xpixmap|x\-xwindowdump)$/i;

     return rFilter.test(src) || Filter.test(src);

 }

验证是否为颜色

复制代码 代码如下:

function detectColor(value) {

    var pattern = /^#[0-9a-fA-F]{6}$/; //#XXXXXX

    var result;

    var rgbRegex = /(^rgb\((\d+),\s*(\d+),\s*(\d+)\)$)|(^rgba\((\d+),\s*(\d+),\s*(\d+)(,\s*\d+\.\d+)*\)$)/;

    if (pattern.test(value)) {

        result = value;

    } else if (rgbRegex.test(value)) { //rgba(0, 0, 0, 0)

        result = value;

    }

    return result;

}

将RGB转化为HEX:

复制代码 代码如下:

 function zero_fill_hex(num, digits) {

     var s = num.toString(16);

     while (s.length < digits) {

         s = "0" + s;

     }

     return s;

 }

 function rgb2hex(rgb) {

     if (rgb.charAt(0) == '#') {

         return rgb;

     }

     var ds = rgb.split(/\D+/);

     var decimal = Number(ds[1]) * 65536 + Number(ds[2]) * 256 + Number(ds[3]);

     return "#" + zero_fill_hex(decimal, 6);

 }

验证是否为Email地址:

复制代码 代码如下:

 function testEmail (value, target) {

     value = value.trim();

     if (!/^\w+([\.-]?\w+)*@\w+([\.-]?\w+)*(\.\w{2,3})+$/.test(value)) {

         target.val("");

         alert("Please fill in the correct E-mail address!");

     }

 }

将图片src转化为data 64:

复制代码 代码如下:

function createImgData(img) {

    var image = new Image();

    image.src = img.src || img;

    var tmpCanvas = $("<canvas></canvas>")[0];

    var tmpCtx = tmpCanvas.getContext("2d");

    if (tmpCanvas) {

        tmpCanvas.width = image.width;

        tmpCanvas.height = image.height;

        tmpCtx.drawImage(image, 0, 0);

        return tmpCanvas.toDataURL();

    }

}

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
 2

<HTML>
 3

<HEAD>
 4

<TITLE> New Document </TITLE>
 5

<META NAME="Generator" CONTENT="EditPlus">
 6

<
23ddc
;META NAME="Author" CONTENT="">
 7

<META NAME="Keywords" CONTENT="">
 8

<META NAME="Description" CONTENT="">
 9

<script language=javascript>
10

    String.prototype.Replace = function(oldValue,newValue) 
11

    { 
12

        var reg = new RegExp(oldValue,"g"); 
13

        return this.replace(reg, newValue); 
14

    }
15

    //字符串替换;曾经很头疼写了很多代码,还是这个简单
16

    function replace(obj)
17

    {
18

        alert(obj.value.Replace("a","d"));
19

    }
20


21

    // 另存为文件
22

    function SaveCode(obj, filename) 
23

    {
24

        var win = window.open('', '_blank', 'top=100'); 
25

        var code = obj.innerText; 
26

        code = code == null || code == "" ? obj.value : code; 
27

        win.opener = null;
28

        win.document.write(code);
29

        win.document.execCommand('saveas', true, filename);
30

        win.close();
31

    }
32

    // 问候
33

    window.onload = function()
34

    {    
35

        var now = new Date();
36

        var hour = now.getHours();
37

        var greeting;
38

        if (hour < 6)
39

            greeting = "凌晨好";
40

        else if (hour < 10)
41

            greeting = "早上好";
42

        else if (hour < 14)
43

            greeting = "中午好";
44

        else if (hour < 18)
45

            greeting = "下午好";
46

        else 
47

            greeting = "晚上好";
48

            
49

        document.getElementById("hi").innerHTML = "<font color=red>" + greeting + "</font>" ;
50

    }
51

    // 将光标停在对象的最后
52

    function PutCursorAtLast(obj) 
53

    {  
54

        obj.focus();
55

        var range = obj.createTextRange(); 
56

        range.moveStart('character',obj.value.length); 
57

        range.collapse(true); 
58

        range.select(); 
59

    }
60

    // 将光标停在对象的最前
61

    function PutCursorAtFirst(obj) 
62

    {  
63

        obj.focus();
64

        var range = obj.createTextRange(); 
65

        range.moveStart('character',0); 
66

        range.collapse(true); 
67

        range.select(); 
68

    }
69

</script>
70

</HEAD>
71


72

<BODY>
73

    <span id="hi"></span>
74

    <br/>
75

    <span> curssor at last </span>
76

    <br/>
77

    <input type=text value="curssor at last" onclick=PutCursorAtLast(this)>
78

    <br/>
79

    <span> curssor at first </span>
80

    <br/>
81

    <input type=text value="curssor at first" onclick=PutCursorAtFirst(this)>
82

    <br/>
83

    <span> String.Replace </span>
84

    <br/>
85

    <INPUT TYPE=TEXT value="replace" ONCLICK=replace(this)>
86

    <br/>
87

    <span> save file </span>
88

    <br/>
89

    <input type=text value="hello word" onclick=SaveCode(this,"save")>
90

</BODY>
91

</HTML>
92



// 返回字符的长度,一个中文算2个


String.prototype.ChineseLength=function()





    return this.replace(/[^\x00-\xff]/g,"**").length;


}


// 判断字符串是否以指定的字符串结束


String.prototype.EndsWith = function(str) 


{


    return this.substr(this.length - str.length) == str;


}


// 去掉字符左端的的空白字符


String.prototype.LeftTrim = function()


{


    return this.replace(/(^[\\s]*)/g, "");


}


// 去掉字符右端的空白字符


String.prototype.RightTrim = function()


{


    return this.replace(/([\\s]*$)/g, "");


}


// 判断字符串是否以指定的字符串开始


String.prototype.StartsWith = function(str) 


{


    return this.substr(0, str.length) == str;


}


// 去掉字符两端的空白字符


String.prototype.Trim = function()


{


    return this.replace(/(^\s*)|(\s*$)/g, "");


}
{
3

    var date = new Date(a, b - 1, c);
4

    return Math.ceil((c + 7 - (date.getDay() || 7)) / 7);
5

}
/* 手机类型判断 */

复制代码 代码如下:

var BrowserInfo = {

    userAgent: navigator.userAgent.toLowerCase()

    isAndroid: Boolean(navigator.userAgent.match(/android/ig)),

    isIphone: Boolean(navigator.userAgent.match(/iphone|ipod/ig)),

    isIpad: Boolean(navigator.userAgent.match(/ipad/ig)),

    isWeixin: Boolean(navigator.userAgent.match(/MicroMessenger/ig)),

}

/* 返回字符串长度,汉子计数为2  */

复制代码 代码如下:

function strLength(str) {

    var a = 0;

    for (var i = 0; i < str.length; i++) {

        if (str.charCodeAt(i) > 255)

            a += 2;//按照预期计数增加2

        else

            a++;

    }

    return a;

}

获取url中的参数

复制代码 代码如下:

function GetQueryStringRegExp(name,url) {

    var reg = new RegExp("(^|\\?|&)" + name + "=([^&]*)(\\s|&|$)", "i");

    if (reg.test(url)) return decodeURIComponent(RegExp.$2.replace(/\+/g, " ")); return "";

}

  

/* js 绑定事件 适用于任何浏览器的元素绑定  */

复制代码 代码如下:

function eventBind(obj, eventType, callBack) {

        if (obj.addEventListener) {

            obj.addEventListener(eventType, callBack, false);

        }

        else if (window.attachEvent) {

            obj.attachEvent('on' + eventType, callBack);

        }

        else {

            obj['on' + eventType] = callBack;

        }

    };

eventBind(document, 'click', bodyClick);

  

/* 获得当前浏览器JS的版本 */

复制代码 代码如下:

function getjsversion(){

    var n = navigator;

    var u = n.userAgent;

    var apn = n.appName;

    var v = n.appVersion;

    var ie = v.indexOf('MSIE ');

    if (ie > 0){

        apv = parseInt(i = v.substring(ie + 5));

        if (apv > 3) {

            apv = parseFloat(i);

        }

    } else {

        apv = parseFloat(v);

    }

    var isie = (apn == 'Microsoft Internet Explorer');

    var ismac = (u.indexOf('Mac') >= 0);

    var javascriptVersion = "1.0";

    if (String && String.prototype) {

        javascriptVersion = '1.1';

        if (javascriptVersion.match) {

            javascriptVersion = '1.2';

            var tm = new Date;

            if (tm.setUTCDate) {

                javascriptVersion = '1.3';

                if (isie && ismac && apv >= 5) javascriptVersion = '1.4';

                var pn = 0;

                if (pn.toPrecision) {

                    javascriptVersion = '1.5';

                    a = new Array;

                    if (a.forEach) {

                        javascriptVersion = '1.6';

                        i = 0;

                        o = new Object;

                        tcf = new Function('o', 'var e,i=0;try{i=new Iterator(o)}catch(e){}return i');

                        i = tcf(o);

                        if (i && i.next) {

                            javascriptVersion = '1.7';

                        }

                    }

                }

            }

        }

    }

    return javascriptVersion;

}

/* 获取当前点击事件的Object对象 */

复制代码 代码如下:

function getEvent() {

    if (document.all) {

        return window.event; //如果是ie

    }

    func = getEvent.caller;

    while (func != null) {

        var arg0 = func.arguments[0];

        if (arg0) {

            if ((arg0.constructor == Event || arg0.constructor == MouseEvent)

|| (typeof (arg0) == "object" && arg0.preventDefault && arg0.stopPropagation)) {

                return arg0;

            }

        }

        func = func.caller;

    }

    return null;

};

  

/* 字符串截取方法  */

复制代码 代码如下:

getCharactersLen: function (charStr, cutCount) {

        if (charStr == null || charStr == '') return '';

        var totalCount = 0;

        var newStr = '';

        for (var i = 0; i < charStr.length; i++) {

            var c = charStr.charCodeAt(i);

            if (c < 255 && c > 0) {

                totalCount++;

            } else {

                totalCount += 2;

            }

            if (totalCount >= cutCount) {

                newStr += charStr.charAt(i);

                break;

            }

            else {

                newStr += charStr.charAt(i);

            }

        }

        return newStr;

    }

  

/*  JS 弹出新窗口全屏  */

复制代码 代码如下:

var tmp = window.open("about:blank", "", "fullscreen=1")

                            tmp.moveTo(0, 0);

                            tmp.resizeTo(screen.width + 20, screen.height);

                            tmp.focus();

                            tmp.location.href = 'http://www.che168.com/pinggu/eva_' + msgResult.message[0] + '.html';

 

var config_ = "left=0,top=0,width=" + (window.screen.Width) + ",height=" + (window.screen.Height);

                            window.open('http://www.che168.com/pinggu/eva_' + msgResult.message[0] + '.html', "winHanle", config_);

//模拟form提交打开新页面

var f = document.createElement("form");

                            f.setAttribute('action', 'http://www.che168.com/pinggu/eva_' + msgResult.message[0] + '.html');

                            f.target = '_blank';

                            document.body.appendChild(f);

                            f.submit();

/*   全选/全不选  */

复制代码 代码如下:

function selectAll(objSelect) {

            if (objSelect.checked == true) {

                $("input[name='chkId']").attr("checked", true);

                $("input[name='chkAll']").attr("checked", true);

            }

            else if (objSelect.checked == false) {

                $("input[name='chkId']").attr("checked", false);

                $("input[name='chkAll']").attr("checked", false);

            }

        }

  

/* js 判断浏览器  */

复制代码 代码如下:

判断是否是 IE 浏览器

    if (document.all){

        alert(”IE浏览器”);

    }else{

        alert(”非IE浏览器”);

    }

    if (!!window.ActiveXObject){

        alert(”IE浏览器”);

    }else{

        alert(”非IE浏览器”);

    }

判断是IE几

var isIE=!!window.ActiveXObject;

var isIE6=isIE&&!window.XMLHttpRequest;

var isIE8=isIE&&!!document.documentMode;

var isIE7=isIE&&!isIE6&&!isIE8;

if (isIE){

    if (isIE6){

        alert(”ie6″);

    }else if (isIE8){

        alert(”ie8″);

    }else if (isIE7){

        alert(”ie7″);

    }

}

  

/* 判断浏览器 */

复制代码 代码如下:

function getOs() {

    if (navigator.userAgent.indexOf("MSIE 8.0") > 0) {

        return "MSIE8";

    }

    else if (navigator.userAgent.indexOf("MSIE 6.0") > 0) {

        return "MSIE6";

    }

    else if (navigator.userAgent.indexOf("MSIE 7.0") > 0) {

        return "MSIE7";

    }

    else if (isFirefox = navigator.userAgent.indexOf("Firefox") > 0) {

        return "Firefox";

    }

    if (navigator.userAgent.indexOf("Chrome") > 0) {

        return "Chrome";

    }

    else {

        return "Other";

    }

}

  

/*  JS判断两个日期大小 适合 2012-09-09 与2012-9-9 两种格式的对比  */

复制代码 代码如下:

//得到日期值并转化成日期格式,replace(/\-/g, "\/")是根据验证表达式把日期转化成长日期格式,这样再进行判断就好判断了

        function ValidateDate() {

            var beginDate = $("#t_datestart").val();

            var endDate = $("#t_dateend").val();

            if (beginDate.length > 0 && endDate.length>0) {

                var sDate = new Date(beginDate.replace(/\-/g, "\/"));

                var eDate= new Date(endDate.replace(/\-/g, "\/"));

                if (sDate > eDate) {

                    alert('开始日期要小于结束日期');

                    return false;

                }

            }

        }

  

/* 移除事件 */

复制代码 代码如下:

this.moveBind = function (objId, eventType, callBack) {

    var obj = document.getElementById(objId);

    if (obj.removeEventListener) {

        obj.removeEventListener(eventType, callBack, false);

    }

    else if (window.detachEvent) {

        obj.detachEvent('on' + eventType, callBack);

    }

    else {

        obj['on' + eventType] = null;

    }

}

  

/* 回车提交 */

复制代码 代码如下:

$("id").onkeypress = function (event) {

    event = (event) ? event : ((window.event) ? window.event : "")

    keyCode = event.keyCode ? event.keyCode : (event.which ? event.which : event.charCode);

    if (keyCode == 13) {

        $("SubmitLogin").onclick();

    }

}

  

/* JS 执行计时器 */

复制代码 代码如下:

timeStart = new Date().getTime();

timesEnd = new Date().getTime();

document.getElementById("time").innerHTML = timesEnd - timeStart;

 

/* JS 写Cookie */

复制代码 代码如下:

function setCookie(name, value, expires, path, domain) {

    if (!expires) expires = -1;

    if (!path) path = "/";

    var d = "" + name + "=" + value;

    var e;

    if (expires < 0) {

        e = "";

    }

    else if (expires == 0) {

        var f = new Date(1970, 1, 1);

        e = ";expires=" + f.toUTCString();

    }

    else {

        var now = new Date();

        var f = new Date(now.getTime() + expires * 1000);

        e = ";expires=" + f.toUTCString();

    }

    var dm;

    if (!domain) {

        dm = "";

    }

    else {

        dm = ";domain=" + domain;

    }

    document.cookie = name + "=" + value + ";path=" + path + e + dm;

};

  

/* JS 读Cookie  */

复制代码 代码如下:

function readCookie(name) {

    var nameEQ = name + "=";

    var ca = document.cookie.split(';');

    for (var i = 0; i < ca.length; i++) {

        var c = ca[i];

        while (c.charAt(0) == ' ') c = c.substring(1, c.length);

        if (c.indexOf(nameEQ) == 0) {

            return decodeURIComponent(c.substring(nameEQ.length, c.length))

        }

    } return null

}

  

/*  Ajax 请求  */

复制代码 代码如下:

C.ajax = function (args) {

    var self = this;

    this.options = {

        type: 'GET',

        async: true,

        contentType: 'application/x-www-form-urlencoded',

        url: 'about:blank',

        data: null,

        success: {},

        error: {}

    };

    this.getXmlHttp = function () {

        var xmlHttp;

        try {

            xmlhttp = new XMLHttpRequest();

        }

        catch (e) {

            try {

                xmlhttp = new ActiveXObject("Msxml2.XMLHTTP");

            }

            catch (e) {

                xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");

            }

        }

        if (!xmlhttp) {

            alert('您的浏览器不支持AJAX');

            return false;

        }

        return xmlhttp;

    };

    this.send = function () {

        C.each(self.options, function (key, val) {

            self.options[key] = (args[key] == null) ? val : args[key];

        });

        var xmlHttp = new self.getXmlHttp();

        if (self.options.type.toUpperCase() == 'GET') {

            xmlHttp.open(self.options.type, self.options.url + (self.options.data == null ? "" : ((/[?]$/.test(self.options.url) ? '&' : '?') + self.options.data)), self.options.async);

        }

        else {

            xmlHttp.open(self.options.type, self.options.url, self.options.async);

            xmlHttp.setRequestHeader('Content-Length', self.options.data.length);

        }

        xmlHttp.setRequestHeader('Content-Type', self.options.contentType);

        xmlHttp.onreadystatechange = function () {

            if (xmlHttp.readyState == 4) {

                if (xmlHttp.status == 200 || xmlHttp.status == 0) {

                    if (typeof self.options.success == 'function') self.options.success(xmlHttp.responseText);

                    xmlHttp = null;

                }

                else {

                    if (typeof self.options.error == 'function') self.options.error('Server Status: ' + xmlHttp.status);

                }

            }

        };

        xmlHttp.send(self.options.type.toUpperCase() == 'POST' ? self.options.data.toString() : null);

    };

    this.send();

};

/*  JS StringBuilder 用法  */

复制代码 代码如下:

function StringBuilder() {

    this.strings = new Array;

};

StringBuilder.prototype.append = function (str) {

    this.strings.push(str);

};

StringBuilder.prototype.toString = function () {

    return this.strings.join('');

};

  

/* JS 加载到顶部LoadJS  */

复制代码 代码如下:

function loadJS (url, fn) {

        var ss = document.getElementsByName('script'),

            loaded = false;

        for (var i = 0, len = ss.length; i < len; i++) {

            if (ss[i].src && ss[i].getAttribute('src') == url) {

                loaded = true;

                break;

            }

        }

        if (loaded) {

            if (fn && typeof fn != 'undefined' && fn instanceof Function) fn();

            return false;

        }

        var s = document.createElement('script'),

            b = false;

        s.setAttribute('type', 'text/javascript');

        s.setAttribute('src', url);

        s.onload = s.onreadystatechange = function () {

            if (!b && (!this.readyState || this.readyState == 'loaded' || this.readyState == 'complete')) {

                b = true;

                if (fn && typeof fn != 'undefined' && fn instanceof Function) fn();

            }

        };

        document.getElementsByTagName('head')[0].appendChild(s);

    },

    bind: function (objId, eventType, callBack) {  //适用于任何浏览器的绑定

        var obj = document.getElementById(objId);

        if (obj.addEventListener) {

            obj.addEventListener(eventType, callBack, false);

        }

        else if (window.attachEvent) {

            obj.attachEvent('on' + eventType, callBack);

        }

        else {

            obj['on' + eventType] = callBack;

        }

    }

function JSLoad (args) {

        s = document.createElement("script");

        s.setAttribute("type", "text/javascript");

        s.setAttribute("src", args.url);

        s.onload = s.onreadystatechange = function () {

            if (!s.readyState || s.readyState == "loaded" || s.readyState == "complete") {

                if (typeof args.callback == "function") args.callback(this, args);

                s.onload = s.onreadystatechange = null;

                try {

                    s.parentNode && s.parentNode.removeChild(s);

                } catch (e) { }

            }

        };

        document.getElementsByTagName("head")[0].appendChild(s);

    }

  

/*  清空 LoadJS 加载到顶部的js引用  */

复制代码 代码如下:

function ClearHeadJs  (src) {

        var js = document.getElementsByTagName('head')[0].children;

        var obj = null;

        for (var i = 0; i < js.length; i++) {

            if (js[i].tagName.toLowerCase() == "script" && js[i].attributes['src'].value.indexOf(src) > 0) {

                obj = js[i];

            }

        }

        document.getElementsByTagName('head')[0].removeChild(obj);

    };

  

/*  JS 替换非法字符主要用在密码验证上出现的特殊字符  */

复制代码 代码如下:

function URLencode(sStr) {

    return escape(sStr).replace(/\+/g, '%2B').replace(/\"/g, '%22').replace(/\'/g, '%27').replace(/\//g, '%2F');

};

  

/*  按Ctrl + Entert 直接提交表单   */

复制代码 代码如下:

document.body.onkeydown = function (evt) {

    evt = evt ? evt : (window.event ? window.event : null);

    if (13 == evt.keyCode && evt.ctrlKey) {

        evt.returnValue = false;

        evt.cancel = true;

        PostData();

    }

};

  
/* 获取当前时间  */

复制代码 代码如下:

function GetCurrentDate() {

        var d = new Date();

        var y = d.getYear()+1900;

        month = add_zero(d.getMonth() + 1),

        days = add_zero(d.getDate()),

        hours = add_zero(d.getHours());

        minutes = add_zero(d.getMinutes()),

        seconds = add_zero(d.getSeconds());

        var str = y + '-' + month + '-' + days + ' ' + hours + ':' + minutes + ':' + seconds;

        return str;

    };

    function add_zero(temp) {

        if (temp < 10) return "0" + temp;

        else return temp;

    }

  
/* Js 去掉空格方法:  */

复制代码 代码如下:

String.prototype.Trim = function()

{ return this.replace(/(^\s*)|(\s*$)/g, ""); }

String.prototype.LTrim = function()

{return this.replace(/(^\s*)/g, "");}

String.prototype.RTrim = function()

{return this.replace(/(\s*$)/g, "");}

/* js 动态移除 head 里的 js 引用  */

复制代码 代码如下:

this.ClearHeadJs = function (src) {

    var js = document.getElementsByTagName('head')[0].children;

    var obj = null;

    for (var i = 0; i < js.length; i++) {

        if (js[i].tagName.toLowerCase() == "script" && js[i].attributes['src'].value.indexOf(src) > 0) {

            obj = js[i];

        }

    }

    document.getElementsByTagName('head')[0].removeChild(obj);

};

  

/*  整个UL 点击事件  加在UL里的onclick里 */

复制代码 代码如下:

function CreateFrom(url, params) {

     var f = document.createElement("form");

     f.setAttribute("action", url);

     for (var i = 0; i < params.length; i++) {

         var input = document.createElement("input");

         input.setAttribute("type", "hidden");

         input.setAttribute("name", params[i].paramName);

         input.setAttribute("value", params[i].paramValue);

         f.appendChild(input);

     }

     f.target = "_blank";

     document.body.appendChild(f);

     f.submit();

 };

/* 判断浏览器使用的是哪个 JS 版本 */

复制代码 代码如下:

< script language="javascript">

      var jsversion = 1.0;

    </script>

    <script language="javascript1.1">

      jsversion = 1.1;

    </script>

    <script language="javascript1.2">

      jsversion = 1.2;

    </script>

    <script language="javascript1.3">

      jsversion = 1.3;

    </script>

    <script language="javascript1.4">

      jsversion = 1.4;

    </script>

    <script language="javascript1.5">

      jsversion = 1.5;

    </script>

    <script language="javascript1.6">

      jsversion = 1.6;

    </script>

    <script language="javascript1.7">

      jsversion = 1.7;

    </script>

    <script language="javascript1.8">

      jsversion = 1.8;

    </script>

    <script language="javascript1.9">

      jsversion = 1.9;

    </script>

    <script language="javascript2.0">

      jsversion = 2.0;

    </script>

alert(jsversion);



随着AJAX的流行,js又得到了很多人的重视,js最大的优势就是它能够对html上的所有元素进行操作,包括创建标签元素,更改元素属性等,这样就使得我们能够利用js来实现很多的动态效果,来提供给用户更强的交互性!
Js测试方法<o:p></o:p>

在调试Javascript脚本的时候,如果有错误,IE的状态栏里会有个问号[点击此问号],或者弹出错误框,为了尽快找到错误,下面是常用的调试方法:   

  1,如果出现对象为null或找不不到对象,那就是id,name或DOM写法不对,请检查错误所在的行;   

  2,如果错误定位到一个函数的调用上,说明函数体有问题,到函数体里找原因。   

  3,为了加快速度,可以先用/*       */注释屏蔽掉一部分代码,逐步检查;   

  4,可以增加alert(xxx)来看看变量是否得到了期望的值;   

  5,IE的错误报告往往不准确,比如行18错的话,有时候是19行有问题;   

  6,为了确保代码能够正确运行,在实在不能确定能否出现错误的时候,用try{}catch{}语句在做   

    

  其他的方法,请各位继续添加。

  <script>   

  try{   

        x=y;       //   Cause   an   error.   

  }   

  catch(e){       //   Create   local   variable   e.   

        alert(e);       //   Prints   "[object   Error]".   

        alert(e.number   &   0xFFFF);       //   Prints   5009.   

        alert(e.description);       //   Prints   "'y'   is   undefined".   

  }   

  </script><o:p></o:p>

每一项都是js中的小技巧,但十分的实用! 

1.document.write(""); 输出语句

2.JS中的注释为//

3.传统的HTML文档顺序是:document->html->(head,body)

4.一个浏览器窗口中的DOM顺序是:window->(navigator,screen,history,location,document)

5.得到表单中元素的名称和值:document.getElementById("表单中元素的ID号").name(或value)

6.一个小写转大写的JS: document.getElementById("output").value = document.getElementById("input").value.toUpperCase();

7.JS中的值类型:String,Number,Boolean,Null,Object,Function

8.JS中的字符型转换成数值型:parseInt(),parseFloat()

9.JS中的数字转换成字符型:(""+变量)

10.JS中的取字符串长度是:(length)

11.JS中的字符与字符相连接使用+号.

12.JS中的比较操作符有:==等于,!=不等于,>,>=,<.<=

13.JS中声明变量使用:var来进行声明

14.JS中的判断语句结构:if(condition){}else{}

15.JS中的循环结构:for([initial expression];[condition];[upadte expression]) {inside loop}

16.循环中止的命令是:break

17.JS中的函数定义:function functionName([parameter],...){statement[s]}

18.当文件中出现多个form表单时.可以用document.forms[0],document.forms[1]来代替.

19.窗口:打开窗口window.open(), 关闭一个窗口:window.close(), 窗口本身:self

20.状态栏的设置:window.status="字符";

21.弹出提示信息:window.alert("字符");

22.弹出确认框:window.confirm();

23.弹出输入提示框:window.prompt();

24.指定当前显示链接的位置:window.location.href="URL"

25.取出窗体中的所有表单的数量:document.forms.length

26.关闭文档的输出流:document.close();

27.字符串追加连接符:+=

28.创建一个文档元素:document.createElement(),document.createTextNode()

29.得到元素的方法:document.getElementById()

30.设置表单中所有文本型的成员的值为空:

var form = window.document.forms[0]

for (var i = 0; i if (form.elements.type == "text"){

form.elements.value = "";

}

}

31.复选按钮在JS中判断是否选中:document.forms[0].checkThis.checked (checked属性代表为是否选中返回TRUE或FALSE)

32.单选按钮组(单选按钮的名称必须相同):取单选按钮组的长度document.forms[0].groupName.length

33.单选按钮组判断是否被选中也是用checked.

34.下拉列表框的值:document.forms[0].selectName.options
.value (n有时用下拉列表框名称加上.selectedIndex来确定被选中的值)

35.字符串的定义:var myString = new String("This is lightsword");

36.字符串转成大写:string.toUpperCase(); 字符串转成小写:string.toLowerCase();

37.返回字符串2在字符串1中出现的位置:String1.indexOf("String2")!=-1则说明没找到.

38.取字符串中指定位置的一个字符:StringA.charAt(9);

39.取出字符串中指定起点和终点的子字符串:stringA.substring(2,6);

40.数学函数:Math.PI(返回圆周率),Math.SQRT2(返回开方),Math.max(value1,value2)返回两个数中的最在值,Math.pow(value1,10)返回value1的十次方,Math.round(value1)四舍五入函数,Math.floor(Math.random()*(n+1))返回随机数

41.定义日期型变量:var today = new Date();

42.日期函数列表:dateObj.getTime()得到时间,dateObj.getYear()得到年份,dateObj.getFullYear()得到四位的年份,dateObj.getMonth()得到月份,dateObj.getDate()得到日,dateObj.getDay()得到日期几,dateObj.getHours()得到小时,dateObj.getMinutes()得到分,dateObj.getSeconds()得到秒,dateObj.setTime(value)设置时间,dateObj.setYear(val)设置年,dateObj.setMonth(val)设置月,dateObj.setDate(val)设置日,dateObj.setDay(val)设置星期几,dateObj.setHours设置小时,dateObj.setMinutes(val)设置分,dateObj.setSeconds(val)设置秒 [注意:此日期时间从0开始计]

43.FRAME的表示方式: [window.]frames
.ObjFuncVarName,frames["frameName"].ObjFuncVarName,frameName.ObjFuncVarName

44.parent代表父亲对象,top代表最顶端对象

45.打开子窗口的父窗口为:opener

46.表示当前所属的位置:this

47.当在超链接中调用JS函数时用:(javascript :)来开头后面加函数名

48.在老的浏览器中不执行此JS:<!---->

49.引用一个文件式的JS:<script type="text/javascript" src="aaa.js"></script>

50.指定在不支持脚本的浏览器显示的HTML:<noscript></noscript>

51.当超链和ONCLICK事件都有时,则老版本的浏览器转向a.html,否则转向b.html.例:dfsadf

52.JS的内建对象有:Array,Boolean,Date,Error,EvalError,Function,Math,Number,Object,RangeError,ReferenceError,RegExp,String,SyntaxError,TypeError,URIError

53.JS中的换行:\n

54.窗口全屏大小:<script>function fullScreen(){ this.moveTo(0,0);this.outerWidth=screen.availWidth;this.outerHeight=screen.availHeight;}window.maximize=fullScreen;</script>

55.JS中的all代表其下层的全部元素

56.JS中的焦点顺序:document.getElementByid("表单元素").tabIndex = 1

57.innerHTML的值是表单元素的值:如 则innerHTML的值就是:how are you

58.innerTEXT的值和上面的一样,只不过不会把这种标记显示出来.

59.contentEditable可设置元素是否可被修改,isContentEditable返回是否可修改的状态.

60.isDisabled判断是否为禁止状态.disabled设置禁止状态

61.length取得长度,返回整型数值

62.addBehavior()是一种JS调用的外部函数文件其扩展名为.htc

63.window.focus()使当前的窗口在所有窗口之前.

64.blur()指失去焦点.与FOCUS()相反.

65.select()指元素为选中状态.

66.防止用户对文本框中输入文本:onfocus="this.blur()"

67.取出该元素在页面中出现的数量:document.all.tags("div(或其它HTML标记符)").length

68.JS中分为两种窗体输出:模态和非模态.window.showModaldialog(),window.showModeless()

69.状态栏文字的设置:window.status='文字',默认的状态栏文字设置:window.defaultStatus = '文字.';

70.添加到收藏夹:external.AddFavorite("http://www.dannyg.com","jaskdlf");

71.JS中遇到脚本错误时不做任何操作:window.onerror = doNothing; 指定错误句柄的语法为:window.onerror = handleError;

72.JS中指定当前打开窗口的父窗口:window.opener,支持opener.opener...的多重继续.

73.JS中的self指的是当前的窗口

74.JS中状态栏显示内容:window.status="内容"

75.JS中的top指的是框架集中最顶层的框架

76.JS中关闭当前的窗口:window.close();

77.JS中提出是否确认的框:if(confirm("Are you sure?")){alert("ok");}else{alert("Not Ok");}

78.JS中的窗口重定向:window.navigate("http://www.sina.com.cn");

79.JS中的打印:window.print()

80.JS中的提示输入框:window.prompt("message","defaultReply");

81.JS中的窗口滚动条:window.scroll(x,y)

82.JS中的窗口滚动到位置:window.scrollby

83.JS中设置时间间隔:setInterval("expr",msecDelay)或setInterval(funcRef,msecDelay)或setTimeout

84.JS中的模态显示在IE4+行,在NN中不行:showModalDialog("URL"[,arguments][,features]);

85.JS中的退出之前使用的句柄:function verifyClose(){event.returnValue="we really like you and hope you will stay longer.";}} window.onbeforeunload=verifyClose;

86.当窗体第一次调用时使用的文件句柄:onload()

87.当窗体关闭时调用的文件句柄:onunload()

88.window.location的属性: protocol(http:),hostname(www.example.com),port(80),host(www.example.com:80),pathname("/a/a.html"),hash("#giantGizmo",指跳转到相应的锚记),href(全部的信息)

89.window.location.reload()刷新当前页面.

90.window.history.back()返回上一页,window.history.forward()返回下一页,window.history.go(返回第几页,也可以使用访问过的URL)

91.document.write()不换行的输出,document.writeln()换行输出

92.document.body.noWrap=true;防止链接文字折行.

93.变量名.charAt(第几位),取该变量的第几位的字符.

94."abc".charCodeAt(第几个),返回第几个字符的ASCii码值.

95.字符串连接:string.concat(string2),或用+=进行连接

96.变量.indexOf("字符",起始位置),返回第一个出现的位置(从0开始计算)

97.string.lastIndexOf(searchString[,startIndex])最后一次出现的位置.

98.string.match(regExpression),判断字符是否匹配.

99.string.replace(regExpression,replaceString)替换现有字符串.

100.string.split(分隔符)返回一个数组存储值.

101.string.substr(start[,length])取从第几位到指定长度的字符串.

102.string.toLowerCase()使字符串全部变为小写.

103.string.toUpperCase()使全部字符变为大写.

104.parseInt(string[,radix(代表进制)])强制转换成整型.

105.parseFloat(string[,radix])强制转换成浮点型.

106.isNaN(变量):测试是否为数值型.

107.定义常量的关键字:const,定义变量的关键字:var

有用的js程序代码:

//去左空格;

function ltrim(s){

return s.replace( /^\s*/, "");

}

//去右空格;

function rtrim(s){

return s.replace( /\s*$/, "");

}

//左右空格;

function trim(s){

return rtrim(ltrim(s));

}

//检查非法字符

//str 要检查的字符

//badwords 非法字符 &|<>=

function checkbadwords(str, badwords) {

if (typeof (str) != "string" || typeof (badwords) != "string") {

return (false);

}

for (i=0; i bad = badwords.charAt(i);

for (j=0; j if (bad == str.charAt(j)) {

return false;

break;

}

}

}

return true;

}

//检查合法字符,限制只能输入的字符

//str 要检查的字符

//goodwords 合法字符 1234567890abcdefghijklmnopqrstuvwxyz

function checkgoodwords(str, goodwords) {

if (typeof (str) != "string" || typeof (goodwords) != "string") {

return (false);

}

for (i=0; i this_str = str.charAt(i);

for (j=0; j if (this_str == goodwords.charAt(j)) {

break;

}

if(j==goodwords.length-1){

return false;

}

}

}

return true;

}

//函 数 名:chkinteger

//功能介绍:检查是否为数字

//参数说明:要检查的字符串

//返 回 值:false:不是 true:是

function chkinteger(checkStr) {

var checkOK = "0123456789+-";

var allValid = true;

for (i=0; i ch = checkStr.charAt(i);

if (checkOK.indexOf(ch) == -1) {

allValid = false;

break;

}

if ((ch == '+' || ch == '-') && i>0) {

allValid = false;

break;

}

}

return (allValid);

}

//函 数 名:chklength

//功能介绍:检查字符串的长度

//参数说明:要检查的字符串

//返 回 值:字节长度值

function chklength(checkStr) {

var n = 0;

for (i=0; i chcode = checkStr.charCodeAt(i);

if (chcode>=0 && chcode<=255) {

n++;

} else {

n += 2;

}

}

return (n);

}<o:p></o:p>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  javascript