一,获取客户端状态

1、获取cookie

function cookieInfo() {
setcookie('cookie_test','1');
var cookie_test = getcookie('cookie_test');
if( '1' != cookie_test)
{
return '关闭';
}else
{
return '开启';
}
} function setcookie(name,value)//两个参数,一个是cookie的名子,一个是值
{
var exp = new Date();
exp.setTime(exp.getTime() + 10*1000);
document.cookie = name + "="+ escape(value) + ";expires=" + exp.toGMTString();
}
function getcookie(name)//取cookies函数
{
var arr = document.cookie.match(new RegExp("(^| )"+name+"=([^;]*)(;|$)"));
if(arr != null) return unescape(arr[2]); return null; }

  

  

  

2、获取操作系统

function osInfo() {

    var sUserAgent = navigator.userAgent;

    var isWin = (navigator.platform === "Win32") || (navigator.platform === "Windows");
var isMac = (navigator.platform === "Mac68K") || (navigator.platform === "MacPPC") || (navigator.platform === "Macintosh") || (navigator.platform === "MacIntel");
var bIsIpad = sUserAgent.match("iPad");
var bIsIphoneOs = sUserAgent.match("iPhone");
var isUnix = (navigator.platform === "X11") && !isWin && !isMac;
var isLinux = (String(navigator.platform).indexOf("Linux") > -1);
var bIsAndroid = sUserAgent.match("Android");
var bIsCE = sUserAgent.match("Windows CE") || sUserAgent.match("WinCE") || sUserAgent.match("WindowsCE");
var bIsWM = sUserAgent.match("Windows Mobile");
var bIsWP = sUserAgent.match("Windows Phone OS");
if (bIsIpad || bIsIphoneOs)
return 'IOS'; if (isMac)
return "Mac";
if (isUnix)
return "Unix";
if (isLinux) {
if (bIsAndroid)
return "Android";
else
return "Linux";
}
if (bIsCE)
return 'Windows CE';
if (bIsWM)
return 'Windows Mobile';
if (bIsWP)
return 'Windows Phone'; if (sUserAgent.match("BlackBerry"))
return "BlackBerry OS";
if (sUserAgent.match("RIM Tablet OS"))
return "BlackBerry Tablet OS";
if (sUserAgent.match("(?:web|hpw)OS"))
return "webOS";
if (sUserAgent.match("SymbianOS/9.1") || sUserAgent.match("Series[ ]?60") || sUserAgent.match("S60"))
return "Series60"; if (isWin) {
var isWin2K = sUserAgent.indexOf("Windows NT 5.0") > -1 || sUserAgent.indexOf("Windows 2000") > -1;
if (isWin2K)
return "Win2000";
var isWinXP = sUserAgent.indexOf("Windows NT 5.1") > -1 ||
sUserAgent.indexOf("Windows XP") > -1;
if (isWinXP)
return "WinXP";
var isWin2003 = sUserAgent.indexOf("Windows NT 5.2") > -1 || sUserAgent.indexOf("Windows 2003") > -1;
if (isWin2003)
return "Win2003";
var isWinVista = sUserAgent.indexOf("Windows NT 6.0") > -1 || sUserAgent.indexOf("Windows Vista") > -1;
if (isWinVista)
return "WinVista";
var isWin7 = sUserAgent.indexOf("Windows NT 6.1") > -1 || sUserAgent.indexOf("Windows 7") > -1;
if (isWin7)
return "Win7";
var isWin8 = sUserAgent.indexOf("Windows NT 6.2") > -1 || sUserAgent.indexOf("Windows 8") > -1;
if (isWin8)
return "Win8";
}
return "other";
}

  

3、获取flash状态

 function getFlashVersion() {
var flashVer = NaN;
var ua = navigator.userAgent; if (window.ActiveXObject) {
var swf = new ActiveXObject('ShockwaveFlash.ShockwaveFlash'); if (swf) {
flashVer = Number(swf.GetVariable('$version').split(' ')[1].replace(/,/g, '.').replace(/^(d+.d+).*$/, "$1"));
}
} else {
if (navigator.plugins && navigator.plugins.length > 0) {
var swf = navigator.plugins['Shockwave Flash']; if (swf) {
var arr = swf.description.split(' ');
for (var i = 0, len = arr.length; i < len; i++) {
var ver = Number(arr[i]); if (!isNaN(ver)) {
flashVer = arr[i];
break;
}
}
}
}
}
if (!isNaN(flashVer)) {
return flashVer;
} else {
return '未安装';
}
}

4、获取浏览器版本

function  getBrowser(){
//获取用户浏览器
var W = window,B = {};
var agent = navigator.userAgent;
if (W.ActiveXObject) {
B.name = 'ie';
B.ver = 9 - (agent.indexOf("Trident/5.0") == -1) - (!W.XDomainRequest) - (!W.XMLHttpRequest);
} else {
if (document.getBoxObjectFor || W.mozInnerScreenX != undefined) {
B.name = 'firefox';
B.ver= (m = /(?:Firefox|GranParadiso|Iceweasel|Minefield).(\d+\.\d+)/i.exec(agent)) ? parseFloat(m[1], 10) : 3.3
} else { if (!navigator.taintEnabled) {
m = /AppleWebKit.(\d+\.\d+)/i.exec(agent);
B.name = 'webkit';
B.ver = m ? parseFloat(m[1], 10) : document.evaluate ? (document.querySelector ? 525 : 420) : 419;
if ((m = /Chrome.(\d+\.\d+)/i.exec(agent)) || W.chrome) {
B.name = 'chrome';
B.ver = m ? parseFloat(m[1], 10) : 2
} else {
if ((m = /Version.(\d+\.\d+)/i.exec(agent)) || W.safariHandler) {
B.name = 'safari';
B.ver = m ? parseFloat(m[1], 10) : 3.3
}
}
} else {
if (W.opera) {
B.name = 'opera';
B.ver = parseFloat(navigator.appVersion, 10)
} else {
B.name = 'ie';
B.ver = 6
}
}
}
}
return B.name + ':'+B.ver;
}

  

5、本地存储

function localStorageInfo() {
try {
if ('localStorage' in window && window['localStorage'] !== null) {
return "开启";
}
return "关闭";
} catch (e) {
return "关闭";
}
}

  


二,js 用法心得

1,setTimeout

setTimeout(function () {
},1000); 定时器,1秒钟后执行,这个函数是不阻塞的,代码该往下执行就执行,不会到他这里停滞1秒,所以这个方法不适合做和sleep类似的功能。

2,new Image

      var img = new Image();
img.src = new_src;
img.id = num;
img.className = "hide"; 下面这个方法是用 new 的方法增加一个监听器,就比如说 onerror ,onclick,onload,之类的方法都需要这么做 img.addEventListener("error", function (event) {
console.log($(ths));
var x = $(event.target).attr('id');
// var x = $(img).attr('id');
console.log(x,"xxxxxxxxxxxxx")
}); event 是当前这个标签得到对象,如果想获取当前这个对象的内容使用event就可以了。

  

js 使用技巧的更多相关文章

  1. [转载]Js小技巧||给input type=“password”的输入框赋默认值

    http://www.cnblogs.com/Raywang80s/archive/2012/12/06/2804459.html [转载]Js小技巧||给input type="passw ...

  2. 一探前端开发中的JS调试技巧

    前言 调试技巧,在任何一项技术研发中都可谓是必不可少的技能.掌握各种调试技巧,必定能在工作中起到事半功倍的效果.譬如,快速定位问题.降低故障概率.帮助分析逻辑错误等等.而在互联网前端开发越来越重要的今 ...

  3. JS小技巧大本事(持续更新)

    1. 复制N个字符 String.prototype.repeat = function(num){ return (new Array(++num)).join(this); } var a = ' ...

  4. Js常用技巧

    摘录:http://crasywind.blog.163.com/blog/static/7820316920091011643149/ js 常用技巧 1. on contextmenu=" ...

  5. Backbone.js的技巧和模式

    Backbone.js的技巧和模式 Backbone.js的技巧和模式   本文由白牙根据Phillip Whisenhunt的<Backbone.js Tips And Patterns> ...

  6. 前端开发中的JS调试技巧

    前言:调试技巧,在任何一项技术研发中都可谓是必不可少的技能.掌握各种调试技巧,必定能在工作中起到事半功倍的效果.譬如,快速定位问题.降低故障概率.帮助分析逻辑错误等等.而在互联网前端开发越来越重要的今 ...

  7. js小技巧总结

    js小技巧总结 1.Array.includes条件判断 function test(fruit) { const redFruits = ["apple", "stra ...

  8. 【repost】一探前端开发中的JS调试技巧

    有请提示:文中涉及较多Gif演示动画,移动端请尽量在Wifi环境中阅读 前言:调试技巧,在任何一项技术研发中都可谓是必不可少的技能.掌握各种调试技巧,必定能在工作中起到事半功倍的效果.譬如,快速定位问 ...

  9. JS数组排序技巧汇总(冒泡、sort、快速、希尔等排序)

    本文实例总结了JS数组排序技巧.分享给大家供大家参考,具体如下: 1.冒泡排序 var temp = 0; for (var i = 0; i < array.length; i++) { fo ...

  10. 必备的JS调试技巧汇总

    转自http://www.jb51.net/article/88891.htm 前言:任何一个编程者都少不了要去调试代码,不管你是高手还是菜鸟,调试程序都是一项必不可少的工作.一般来说调试程序是在编写 ...

随机推荐

  1. Java-多线程第三篇3种创建的线程方式、线程的生命周期、线程控制、线程同步、线程通信

    1.Java使用Thread类代表线程.     所有的线程对象必须是Thread类或其子类的实例. 当线程继承Thread类时,直接使用this即可获取当前线程,Thread对象的getName() ...

  2. hive环境

    一.hive安装部署 1.hive安装及配置 (1)解压apache-hive-1.2.1-bin.tar.gz到/opt/module/目录下面 tar -zxvf apache-hive-1.2. ...

  3. Java数组相关算法一

    一.数组反转 1.方法一:创建新数组 int[] arr = {6,29,0,4,3}; int[] arr2 = new int[arr.length]; for (int i = 0; i < ...

  4. Java中的I/O

    1.Java中的I/O分类 I/O分类: 输入流,输出流,或者字节流,字符流 I/O中的四个抽象基类: InputStream,OutputStream:两者属于字节流,前者输入,后者输出.一般后缀名 ...

  5. [POJ3612] Telephone Wire(暴力dp+剪枝)

    [POJ3612] Telephone Wire(暴力dp+剪枝) 题面 有N根电线杆,初始高度为h[i],要给相邻的两根连线.可以选择拔高其中一部分电线杆,把一根电线杆拔高\(\Delta H\)的 ...

  6. 关于php中trim、ltrim和rtrim

    以ltrim为例 先看手册说明先 定义和用法 ltrim() 函数从字符串左侧删除空格或其他预定义字符. 语法 ltrim(string,charlist) 参数 描述 string 必需.规定要转换 ...

  7. python学习第三十天函数的形参,实参及函数文档

    python函数的形参是定义函数def 函数名 小括号里面的变量,实参是调用函数时候的值,函数文档是提供函数功能的开发文档,下面 详细说明系列方法 1,函数的形参 def chan(name): pr ...

  8. python学习二十一天文件可读,可写,可执行的操作

    文件无非是可读,可写,可执行的操作,分别对应的模式 r ,w,x,只读模式,只写模式,只执行模式,a模式为追加模式,实际也是写操作模式,r+,w+,a+ 可读写模式,下面详细说模式的用法 1,文件的模 ...

  9. ORACLE数据字典DBA视图

    select  *  from  DBA_ALL_TABLES   --显示数据库中所有表的描述 select  *  from  DBA_CATALOG  --列出所有数据库标,视图,同义词和序列 ...

  10. MySQL --13 主从复制

    目录 一.主从复制简介 二.主从复制原理 三.主从复制搭建实战 四.主从复制基本故障处理 五.延时从库 企业案例: 模拟环境 一.主从复制简介 复制是 MySQL 的一项功能,允许服务器将更改从一个实 ...