首页 > 网站 > WEB开发 > 正文

js常用函数整理

2024-04-27 14:12:27
字体:
来源:转载
供稿:网友

js常用函数整理

前言 

  整理了一些js常用函数,包括浏览器兼容, 常用字符串处理,获取信息以及移动端信息获取等 ,版本不断补充更新中,

其中大部分函数都已经验证过,如果有错误请及时反馈或者有好的一些工具函数,也可以提出来添加进去,针对相同作用的不同函数,

我会进行优化调整 并且测试,尽可能保证个浏览器兼容,排除冲突等。

  先放出50个左右 JS代码如下 可直接copy到JS文件当中,目录不代表顺序,有些函数目录中或许没有显示。如有缺少 还请提出

让我更好的完善。

代码

/** * JSFrame Name:EasyJs * File Name:JSFrame * Date:2014-11-28 上午10:50:09 * Copyright (c) 2014, China Link Communications LTD All Rights Reserved. * Author:by sicd * Describe: *         Commonly used function of js code * *//** 1、原生javaScript实现字符串长度截取 2、原生Javascript获取域名主机 3、原生JavaScript清除空格 4、原生JavaScript替换全部 5、原生JavaScript转义html标签 6、原生JavaScript还原html标签 7、原生JavaScript时间日期格式转换 8、原生JavaScript判断是否为数字类型 9、原生JavaScript设置cookie值 10、原生JavaScript获取cookie值 11、原生JavaScript加入收藏夹 12、原生JavaScript设为首页 13、原生JavaScript判断IE6 14、原生JavaScript加载样式文件 15、原生JavaScript返回脚本内容 16、原生JavaScript清除脚本内容 17、原生JavaScript动态加载脚本文件 18、原生JavaScript返回按ID检索的元素对象 19、原生JavaScript返回浏览器版本内容 20、原生JavaScript元素显示的通用方法 21、原生JavaScript中有insertBefore方法,可惜却没有insertAfter方法?用如下函数实现 22、原生JavaScript中兼容浏览器绑定元素事件 23、原生JavaScript光标停在文字的后面,文本框获得焦点时调用 24、原生JavaScript检验URL链接是否有效 25、原生JavaScript格式化CSS样式代码 26、原生JavaScript压缩CSS样式代码 27、原生JavaScript获取当前路径 28、原生JavaScriptIP转成整型 29、原生JavaScript整型解析为IP地址 30、原生JavaScript实现checkbox全选与全不选 31、原生JavaScript判断是否移动设备 32、原生JavaScript判断是否移动设备访问 33、原生JavaScript判断是否苹果移动设备访问 34、原生JavaScript判断是否安卓移动设备访问 35、原生JavaScript判断是否Touch屏幕 36、原生JavaScript判断是否在安卓上的谷歌浏览器 37、原生JavaScript判断是否打开视窗 38、原生JavaScript获取移动设备初始化大小 39、原生JavaScript获取移动设备最大化大小 40、原生JavaScript获取移动设备屏幕宽度 41、原生JavaScript完美判断是否为网址 42、原生JavaScript根据样式名称检索元素对象 43、原生JavaScript判断是否以某个字符串开头 44、原生JavaScript判断是否以某个字符串结束 45、原生JavaScript返回IE浏览器的版本号 46、原生JavaScript获取页面高度 47、原生JavaScript获取页面scrollLeft 48、原生JavaScript获取页面可视宽度 49、原生JavaScript获取页面宽度 **//** * 字符串长度截取 params: str:字符串 length:长度 */function cutstr(str, length) {    var temp;    var icount = 0;    var patrn = /[^/x00-/xff]/;    var strre = "";    for ( var i = 0; i < str.length; i++) {        if (icount < len - 1) {            temp = str.substr(i, 1);            if (patrn.exec(temp) == null) {                icount = icount + 1;            } else {                icount = icount + 2;            }            strre += temp;        } else {            break;        }    }    return strre + "...";}/** * 获取域名主机 params: url:域名 */function getHost(url) {    var host = "null";    if (typeof url == "undefined" || null == url) {        url = window.location.href;    }    var regex = /^/w+/:////([^//]*).*/;    var match = url.match(regex);    if (typeof match != "undefined" && null != match) {        host = match[1];    }    return host;}/** * 清除空格 为String 对象添加方法 trim() 以此兼容不支持此方法的浏览器 */if (!String.PRototype.trim) {    String.prototype.trim = function() {        var reExtraspace = /^/s*(.*?)/s+$/;        return this.replace(reExtraSpace, "$1");    };}/** * 替换全部,多种方式的替换规则 为String 对象添加方法 replaceAll 兼容浏览器 *  * 第三参数 修饰符 描述 i 执行对大小写不敏感的匹配。 g 执行全局匹配(查找所有匹配而非在找到第一个匹配后停止)。 m 执行多行匹配。 */if (!String.prototype.replaceAll) {    String.prototype.replaceAll = function(s1, s2, type) {        return this.replace(new RegExp(s1, type), s2);    };}/** * 转义html标签 */function htmlEncode(text) {    return text.replace(/&/g, '&amp').replace(//"/g, '&quot;').replace(/</g,            '&lt;').replace(/>/g, '&gt;');}/** * 还原html标签 */function htmlDecode(text) {    return text.replace(/&amp;/g, '&').replace(/&quot;/g, '/"').replace(            /&lt;/g, '<').replace(/&gt;/g, '>');}/** * 时间日期格式转换 (按需更改,是否调用原方法, 还是重写) */if (!Date.prototye.format && !Date.prototype.Format) {    Date.prototype.Format = function(formatStr) {        var str = formatStr;        var Week = [ '日', '一', '二', '三', '四', '五', '六' ];        str = str.replace(/yyyy|YYYY/, this.getFullYear());        str = str.replace(/yy|YY/,                (this.getYear() % 100) > 9 ? (this.getYear() % 100).toString()                        : '0' + (this.getYear() % 100));        str = str.replace(/MM/,                (this.getMonth() + 1) > 9 ? (this.getMonth() + 1).toString()                        : '0' + (this.getMonth() + 1));        str = str.replace(/M/g, (this.getMonth() + 1));        str = str.replace(/w|W/g, Week[this.getDay()]);        str = str.replace(/dd|DD/, this.getDate() > 9 ? this.getDate()                .toString() : '0' + this.getDate());        str = str.replace(/d|D/g, this.getDate());        str = str.replace(/hh|HH/, this.getHours() > 9 ? this.getHours()                .toString() : '0' + this.getHours());        str = str.replace(/h|H/g, this.getHours());        str = str.replace(/mm/, this.getMinutes() > 9 ? this.getMinutes()                .toString() : '0' + this.getMinutes());        str = str.replace(/m/g, this.getMinutes());        str = str.replace(/ss|SS/, this.getSeconds() > 9 ? this.getSeconds()                .toString() : '0' + this.getSeconds());        str = str.replace(/s|S/g, this.getSeconds());        return str;    };}/** * 判断是否为数字类型 */function isDigit(value) {    var patrn = /^[0-9]*$/;    if (patrn.exec(value) == null || value == "") {        return false;    } else {        return true;    }}/** * 设置cookie值 escape(str) 对值进行编码 unescape(str)进行解码 (ECMAScript v3 反对使用该方法,应用使用 * decodeURI() 和 decodeURIComponent() 替代它。) *  * param: *  * name:名称 *  * value:名称对应值 *  * path:为了控制cookie可以访问的目录 例: path=/shop";就表示当前cookie仅能在shop目录下使用(url地址)。 *  * expires:过期时间 F * domain : 指定可访问cookie的主机名 域名 */function setCookie(name, value, Hours) {    var d = new Date();    var offset = 8;    var utc = d.getTime() + (d.getTimezoneOffset() * 60000);    var nd = utc + (3600000 * offset);    var exp = new Date(nd);    exp.setTime(exp.getTime() + Hours * 60 * 60 * 1000);    document.cookie = name + "=" + escape(value) + ";path=/;expires="            + exp.toGMTString() + ";domain=sicd.com;";}/** * 获取cookie值 unescape()不推荐使用 用 decodeURI() *  */function getCookie(name) {    var arr = document.cookie            .match(new RegExp("(^| )" + name + "=([^;]*)(;|$)"));    if (arr != null)        return unescape(arr[2]);    return null;}/** * 加入收藏夹 */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() {    if (document.all) {        document.body.style.behavior = 'url(#default#homepage)';        document.body.setHomePage('http://***');    } 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', 'http://***');    }}/** * 判断IE6 设置背景图片缓存解决闪烁问题 (ie6默认背景图片不缓存) *  * document.execCommand() 用法 想了解的童鞋请访问: * http://www.cnblogs.com/sicd/p/4134641.html 记得点个赞哟 ^_^ */var ua = navigator.userAgent.toLowerCase();var isIE6 = ua.indexOf("msie 6") > -1;if (isIE6) {    try {        document.execCommand("BackgroundImageCache", false, true);    } catch (e) {    }}/** * 动态加载 CSS 样式文件 */function LoadStyle(url) {    try {        document.createStyleSheet(url);    } catch (e) {        var cssLink = document.createElement('link');        cssLink.rel = 'stylesheet';        cssLink.type = 'text/css';        cssLink.href = u
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表