28个常用JavaScript方法集锦


Posted in Javascript onJanuary 14, 2015

经常使用的 JS 方法,今天记下,以便以后查询

/* 手机类型判断 */

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);

以上就是本文的全部内容了,希望能对大家有所帮助,也不枉整理这么久了,呵呵。

Javascript 相关文章推荐
jquery和ajax的关系详细介绍
Nov 29 Javascript
JavaScript字符串对象substring方法入门实例(用于截取字符串)
Oct 17 Javascript
一个用jquery写的判断div滚动条到底部的方法【推荐】
Apr 29 Javascript
jQuery获取table行数并输出单元格内容的实现方法
Jun 30 Javascript
JS中用childNodes获取子元素换行会产生一个子元素
Dec 08 Javascript
基于JS实现限时抢购倒计时间表代码
May 09 Javascript
js实现首屏延迟加载实现方法 js实现多屏单张图片延迟加载效果
Jul 17 Javascript
微信小程序报错:this.setData is not a function的解决办法
Sep 27 Javascript
原生js实现trigger方法示例代码
May 22 Javascript
通过vue写一个瀑布流插件代码实例
Sep 07 Javascript
JS 设计模式之:工厂模式定义与实现方法浅析
May 06 Javascript
解决Vue使用bus总线时,第一次路由跳转时数据没成功传递问题
Jul 28 Javascript
jquery单选框radio绑定click事件实现方法
Jan 14 #Javascript
jquery移动节点实例
Jan 14 #Javascript
jquery获取checkbox的值并post提交
Jan 14 #Javascript
js打造数组转json函数
Jan 14 #Javascript
使用jquery 简单实现下拉菜单
Jan 14 #Javascript
jquery实现鼠标滑过小图时显示大图的方法
Jan 14 #Javascript
js实现禁止中文输入的方法
Jan 14 #Javascript
You might like
php UBB 解析实现代码
2011/11/27 PHP
php一些错误处理的方法与技巧总结
2013/08/10 PHP
PHP中使用array函数新建一个数组
2015/11/19 PHP
浅谈PHP检查数组中是否存在某个值 in_array 函数
2016/06/13 PHP
PHP的JSON封装、转变及输出操作示例
2019/09/27 PHP
那些年,我还在学习jquery 学习笔记
2012/03/05 Javascript
datagrid框架的删除添加与修改
2013/04/08 Javascript
js字符串转成JSON
2013/11/07 Javascript
JQuery中使用Ajax赋值给全局变量异常的解决方法
2014/01/10 Javascript
一个可以增加和删除行的table并可编辑表格中内容
2014/06/16 Javascript
jquery操作对象数组元素方法详解
2014/11/26 Javascript
JS数组的常见用法实例
2015/02/10 Javascript
异步安全加载javascript文件的方法
2015/07/21 Javascript
关于jquery中动态增加select,事件无效的快速解决方法
2016/08/29 Javascript
jQuery leonaScroll 1.1 自定义滚动条插件(推荐)
2016/09/17 Javascript
利用VUE框架,实现列表分页功能示例代码
2017/01/12 Javascript
JavaScript自动点击链接 防止绕过浏览器访问的方法
2017/01/19 Javascript
jQuery插件HighCharts绘制2D带Label的折线图效果示例【附demo源码下载】
2017/03/08 Javascript
微信小程序开发之animation循环动画实现的让云朵飘效果
2017/07/14 Javascript
js实现点击图片在屏幕中间弹出放大效果
2019/09/11 Javascript
node.js 使用 net 模块模拟 websocket 握手进行数据传递操作示例
2020/02/11 Javascript
JavaScript 严格模式(use strict)用法实例分析
2020/03/04 Javascript
js实现动态时钟
2020/03/12 Javascript
微信公众号网页分享功能开发的示例代码
2020/05/27 Javascript
npm全局环境变量配置详解
2020/12/15 Javascript
python操作mongodb根据_id查询数据的实现方法
2015/05/20 Python
Django中间件实现拦截器的方法
2018/06/01 Python
Django框架模板文件使用及模板文件加载顺序分析
2019/05/23 Python
python datetime中strptime用法详解
2019/08/29 Python
利用Python裁切tiff图像且读取tiff,shp文件的实例
2020/03/10 Python
Django Path转换器自定义及正则代码实例
2020/05/29 Python
Three Graces London官网:英国奢侈品牌
2021/03/18 全球购物
文明社区申报材料
2014/08/21 职场文书
后进生评语大全
2015/01/04 职场文书
论语读书笔记
2015/06/26 职场文书
Redis+Lua脚本实现计数器接口防刷功能(升级版)
2022/02/12 Redis