JS对URL编码 :encodeURI()

.Net对URL解码:HttpUtility.UrlDecode()

格式化输出百分数

function formatePercent(data){
            if (data != undefined && !isNaN(data))
            {
               data=Number(data)*100;
               return data.toFixed(2)+"%";
            }
           return "";
        }

阻止事件冒泡

function stopBubble(e) {
    // 如果提供了事件对象,则这是一个非IE浏览器
    if (e && e.stopPropagation)
    // 因此它支持W3C的stopPropagation()方法
        e.stopPropagation();
    else
    // 否则,我们需要使用IE的方式来取消事件冒泡
        window.event.cancelBubble = true;
}

//获取dom元素css样式值
function getStyle(dom,attr){
    if(window.getComputedStyle){
      return window.getComputedStyle(dom,false)[attr];
    }else{
      //兼容IE
      return dom.currentStyle[attr];
    }
 }

事件句柄
e || window.event
光标坐标
e.clientX || e.pageX

HtmlCollection转数组
var arry = [].slice.call(lisDom);

function getXY(e){
    var ev = e || window.event;
    //坐标的获取
    //ie678 pageX pageY (包含滚动条的scrollLeft  和scrollTop)
    //ie9+ clientX  clientY (不包含滚动条的scrollLeft  和scrollTop)
    var x=0,y=0;
    if(ev.pageX){
        x = ev.pageX;
        y = ev.pageY;
    }else{
        //拿到scrollTop 和scrollLeft
        var sleft = 0,stop = 0;
        //ie678---
        if(document.documentElement){
            stop =document.documentElement.scrollTop;
            sleft = document.documentElement.scrollLeft;
        }else{
        //ie9+ 谷歌
            stop = document.body.scrollTop;
            sleft = document.body.scrollLeft;
        }    
        x = ev.clientX + sleft;
        y = ev.clientY + stop;
    }
    return {x:x,y:y};
};

// IE 687               IE9
// attachEvent()        addEventListener()
//detachEvent()         removeEventListener()
// e.srcElement         e.target
//cancleBubble(true)    e.stopPropagation()
//return false          e.preventDefault()

//添加事件
function setEvent(dom,type,callback){
    if(document.addEventListener){
        dom.addEventListener(type,callback,false);
    }else if(document.attachEvent){
        dom.attachEvent("on"+type,callback,false);
    }else{
        dom["on"+type]=callback;
    }
}
        
//移除事件
function offEvent(dom,type,callback){
    if(dom.removeEventListener){
        dom.removeEventListener(type,callback);
    }else if(document.detachEvent){
        dom.detachEvent("on"+type,callback);
    }else {
        delete dom["on"+type];
    }
}
        
//阻止浏览器默认行为
function offDefault(e){
    if(event.preventDefault){
        return e.preventDefault();
    }else{
        e.returnValue=false;
    }
}
        
//阻止事件冒泡
function stopEvent(e){
    if(e.stopPropagation){
        e.stopPropagation();
    }else{
        e.cancelBubble=true;
    }
}

//混入
function mix (target,source){
//arguments:类数组---它有数组的长度,下标,但不能调用数组的sort push reverse
    var args = [].slice.call(arguments);
    var i = 1;
    if(args.length == 1){
        return target;
    };
    while((source = args[i++])){
        for(var key in source){
            target[key] = source[key];//混入代码
        }
    }
    return target;
}

//js关闭当前窗口,避免弹出提示框

window.opener=null;
  window.open('','_self');
  window.close();

JsJquery小技巧的更多相关文章

  1. 前端网络、JavaScript优化以及开发小技巧

    一.网络优化 YSlow有23条规则,中文可以参考这里.这几十条规则最主要是在做消除或减少不必要的网络延迟,将需要传输的数据压缩至最少. 1)合并压缩CSS.JavaScript.图片,静态资源CDN ...

  2. Git小技巧 - 指令别名及使用Beyond Compare作为差异比较工具

    前言 本文主要写给使用命令行来操作Git的用户,用于提高Git使用的效率.至于使用命令还是GUI(Tortoise Git或VS的Git插件)就不在此讨论了,大家根据自己的的喜好选择就好.我个人是比较 ...

  3. 分享两个BPM配置小技巧

    1.小技巧 流程图修改后发布的话版本号会+1,修改次数多了之后可能会导致版本号很高,这个时候可以将流程导出,然后删除对应的流程包再导入,发布数据模型和流程图之后,版本清零 2.小技巧 有的同事入职后使 ...

  4. linux系统维护时的一些小技巧,包括系统挂载新磁盘的方法!可收藏!

    这里发布一些平时所用到的小技巧,不多,不过会持续更新.... 1.需要将history创建硬链接ln 全盘需要备份硬链接 ln /etc/xxx /home/xxx 2.root用户不可以远程 /et ...

  5. JS处理事件小技巧

    今天,就分享一下我自己总结的一些JS的小技巧: ①防止鼠标选中事件 <div class="mask" onselectstart="return false&qu ...

  6. iOS:小技巧(不断更新)

    记录下一些不常用技巧,以防忘记,复制用. 1.获取当前的View在Window的frame: UIWindow * window=[[[UIApplication sharedApplication] ...

  7. css小技巧(1)

    1.-webkit-overflow-scrolling: touch; 解决ios滑动时无缓冲问题 2.::-webkit-scrollbar 设置ios滑动时是否显示滚动条 3.::selecti ...

  8. 最强 Android Studio 使用小技巧和快捷键

    写在前面 本文翻译自 Android Studio Tips by Philippe Breault,一共收集了62个 Android Studio 使用小技巧和快捷键. 根据这些小技巧的使用场景,本 ...

  9. ios开发中的小技巧

    在这里总结一些iOS开发中的小技巧,能大大方便我们的开发,持续更新. UITableView的Group样式下顶部空白处理 //分组列表头部空白处理 UIView *view = [[UIViewal ...

随机推荐

  1. IO流分类

    IO流在java中从输入和输出角度分类: 1.输入流 2.输出流 IO流在java中从数据的角度来分类: 1.字符流:文本,我们能读懂的都可以认为是字符流,如:文章,java文件等 字符输入流的超类: ...

  2. vs code自动生成html代码

    在dreamveawer中新建一个htm自动会生成一个标准的html代码,那在vscode得一行一行写吗?太烦了吧,各种关键词搜,哎妈 终于找到了办法,现在这里记录下: 第一步:在空文档中输入! 第二 ...

  3. 【dart学习】-- Dart之元数据

    一,概述 元数据概述  元数据(Metadata),又称中介数据.中继数据,为描述数据的数据(data about data),主要是描述数据属性(property)的信息,用来支持如指示存储位置.历 ...

  4. Golang flag包使用详解(一)

    概述 flag包提供了一系列解析命令行参数的功能接口 命令行语法 命令行语法主要有以下几种形式 -flag //只支持bool类型 -flag=x -flag x //只支持非bool类型 以上语法对 ...

  5. Tomcat运行错误示例

    tomcat运行错误示例 当出现这种错误时,如果是自己配置的tomcat,需要找/conf/server.xml文件. 如果是使用的eclipse tomcat 插件,需要在你的工作空间 找到 如下文 ...

  6. 4.1 react 代码规范

    关于 基础规范 组件结构 命名规范 jsx 书写规范 eslint-plugin-react 关于 在代码的设计上,每个团队可能都有一定的代码规范和模式,好的代码规范能够提高代码的可读性便于协作沟通, ...

  7. 自旋锁spinlock

    1 在单处理器上的实现 单核系统上,不存在严格的并发,因此对资源的共享主要是多个任务分时运行造成的. 只要在某一时段,停止任务切换,并且关中断(对于用户态应用程序,不大可能与中断处理程序抢临界区资源) ...

  8. 拾遗:Gentoo 使用笔记

    零.使用 Git 源 mkdir /etc/portage/repos.conf cd !$ vi gentoo.conf [DEFAULT] main-repo = gentoo [gentoo] ...

  9. Webpack4篇

    [Webpack4篇] webpack4 打包优化策略 当前依赖包的版本 1 优化loader配置 1.1 缩小文件匹配范围(include/exclude) 通过排除node_modules下的文件 ...

  10. DevOps到底是什么鬼?DevOps介绍及工具推荐。

    什么是DevOps DevOps是Development和Operations的组合,是一组过程.方法与系统的统称,用于促进开发(应用程序/软件工程).技术运营和质量保障(QA)部门之间的沟通.协作与 ...