兼容IE8及以上的IE浏览器
1. [代码][HTML]代码 
<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="utf-8">
        <title></title>
    </head>
    <body>
        <div id="test"></div>
    </body>
    <script src="../lib/jquery-1.8.3.min.js"></script>
    <script>
        /*
         * 火狐无 addRule,低版本IE无insertRule,insertRule是w3c标准
         * 此处insertRule -> addRule的代码是因为inserterRule只有
         *2个参数。2个参数转成3个参数状况比较多
         */
        if(!CSSStyleSheet.prototype.insertRule){
            CSSStyleSheet.prototype.insertRule = function(style, index){
                if(!style){
                    return;
                }
                var style = style.split("{");
                if(style.length<2){
                    return;
                }
                this.addRule(style[0], style[1].split("}")[0], index);
            }
        }
         
        /*
         * 火狐无 removeRule,低版本IE无deleteRule
         * delete​Rule是w3c标准音效网
         */http://www.huiyi8.com/yinxiao/​
        if(!CSSStyleSheet.prototype.deleteRule){
            CSSStyleSheet.prototype.deleteRule = function(index){
                this.removeRule(index);
            }
        }
         
        /**
         * 创建一个外部样式表
         */
        function sheet(appendTo){
            var style = document.createElement("style");
            style.type = 'text/css';
            appendTo ? appendTo.append(style) : $("body").append(style);
            return style.sheet ? style.sheet : style.styleSheet;
        }
         
        var sheet = new sheet();
        sheet.insertRule("#test{width:100px;height:100px;background:red;border:5px solid green;}", 0);
        sheet.insertRule("#test{position:absolute;}", 1);
        sheet.insertRule("#test{position:absolute;}", 2);
         
        var mouseDown = false;
        var position;
        var style;
        var target = $("#test");
        var x,y;
        var rule;
        $("#test").mousedown(function(e){
            mouseDown = true;
            x = e.clientX;
            y = e.clientY;
            position = target.position();
        }).mousemove(function(e){
            if(mouseDown == true){
                rule = sheet.cssRules ? sheet.cssRules[2] : sheet.rules[2];
                rule.style.top = (position.top + e.clientY - y) + "px";
                rule.style.left = (position.left + e.clientX - x) + "px";
            }
        }).mouseup(function(){
            mouseDown = false;
        });
    </script>
</html>

js操作创建和操作外部样式的例子的更多相关文章

  1. Gremlins.js – 模拟用户随机操作的 JS 测试库

    Gremlins.js 是基于 JavaScript 编写的 Monkey 测试库,支持 Node.js 平台和浏览器中使用.Gremlins.js 随机模拟用户操作:单击窗口中的任意位置,在表格中输 ...

  2. JS与PHP数组操作的不同

    JS与PHP数组操作的不同 1.JS 中向数组中添加元素,必须指定下标 2.php中向数组中添加元素,可以不指定下标(追加) 3.JS 中数组元素的下标,是连续 4.PHP中数组元素的下标,可以不连续 ...

  3. js中的DOM操作汇总

    一.DOM创建 DOM节点(Node)通常对应于一个标签,一个文本,或者一个HTML属性.DOM节点有一个nodeType属性用来表示当前元素的类型,它是一个整数: Element,元素 Attrib ...

  4. jquery实现点击展开列表同时隐藏其他列表 js 对象操作 对象原型操作 把一个对象A赋值给另一个对象B 并且对象B 修改 不会影响 A对象

    这篇文章主要介绍了jquery实现点击展开列表同时隐藏其他列表的方法,涉及jquery鼠标事件及节点的遍历与属性操作技巧,具有一定参考借鉴价值,需要的朋友可以参考下 本文实例讲述了jquery实现点击 ...

  5. js实现链式操作

    前言:前不久阿里远程面试时问了我一个问题,如下: function Person(){}; var person = new Person(); //实现person.set(10).get()返回2 ...

  6. JS之document对象(找元素、操作内容、操作属性、操作样式及4道例题)

    document对象 一.找元素 1.根据id找 示例: <input id = "a" type="button" value="找元素&qu ...

  7. js基础总结01 --操作DOM

    1.选择对象 通过id来选择绑定一个dom节点 :document.getElementById('p1'): 通过类名来绑定一个类数组的对象集合,:document.getElementsByCla ...

  8. 1 js中常用的操作

    总结一些前端js常用的操作 常用日期操作:前端开发常用 JS 方法 js中array.list.map的遍历:js遍历集合(Array,Map,Set) js中对象的定义:js创建自定义对象的几种方式 ...

  9. day45:JS中的json&JS的BOM操作和DOM操作

    目录 1.补充:CSS中的弹性盒子 2.JS中json的序列化 3.JS中的BOM操作 3.1 location操作 3.2 计时器 4.JS中的DOM操作 4.1 创建标签 4.2 查找标签 4.3 ...

随机推荐

  1. 让Mac OS X下的终端像Linux那样拥有丰富多彩的颜色显示

    我们知道Linux下的命令行终端具有颜色回显功能,用ls命令查看目录或者文件,终端会以不同的颜色来区分:使用vim命令行编辑器打开脚本或其他源程序代码会以语法高亮模式显示.而Mac OS X下的终端却 ...

  2. 激活win10系统的方法(亲测)

    WIN+X 按A (或者点击左下角有个windows小图标“鼠标右键”选择选择“命令提示符号(管理员)”) 输入下面命令,回车(一行按一个回车键)slmgr.vbs /upkslmgr /ipk W2 ...

  3. AC日记——小书童——刷题大军 洛谷 P1926

    题目背景 数学是火,点亮物理的灯:物理是灯,照亮化学的路:化学是路,通向生物的坑:生物是坑,埋葬学理的人. 文言是火,点亮历史宫灯:历史是灯,照亮社会之路:社会是路,通向哲学大坑:哲学是坑,埋葬文科生 ...

  4. Spring拦截器从Request中获取Json格式的数据

    7 package com.newpp.core.interceptor; 8 9 import java.io.BufferedReader; 10 import java.io.ByteArray ...

  5. 如何更改ORACLE 用户的 expired状态

    ORACLE(113) 版权声明:本文为博主原创文章,未经博主允许不得转载. oracle中, 经常用户的状态会变成locked, expired 等状态, 这种情况下怎么处理呢? 首先,  如果是l ...

  6. 33.JAVA编程思想——JAVA IO File类

    33.JAVA编程思想--JAVA IO File类 RandomAccessFile用于包括了已知长度记录的文件.以便我们能用 seek()从一条记录移至还有一条:然后读取或改动那些记录. 各记录的 ...

  7. vim修改二进制文件

    先用vim以二进制格式打开需要编辑或查看的文件,不采用-b参数有时会导致转换错误,详见分隔线后部分.    vim -b file-to-open.dat 然后用xxd把文件转换成十六进制格式 :%! ...

  8. SQL server 数据库测试题

  9. 令人赞叹的 MySQL

    原文链接 译文链接 感谢 艾凌风 小伙伴校稿 令人赞叹的 MySQL 一个很棒的 MySQL 软件.库以及资源列表. 这个列表接受并鼓舞 pull requests,请看 CONTRIBUTING 文 ...

  10. Computer form factor

    http://en.wikipedia.org/wiki/Motherboard_form_factor Computer form factor From Wikipedia, the free e ...