zoukankan      html  css  js  c++  java
  • 2015-02-08——js笔记

    示例1:

            关于事件对象

            MSIE:window.event,  cancelBubble,  returnValue,  srcElement, button(鼠标按键,1,4,2,左中右)

            W3C:event,  stopPropagation(),  preventDefault(),  target,  button(鼠标按键,0,1,2,左中右)

    示例2:

            得到页面中某点坐标

            示例代码:

            function getPointInPage(eventObject) {
                eventObject = eventObject || getEventObject(eventObject);
                var w3cDom = document.documentElement;
                return {
                    'x': eventObject.pageX || (eventObject.clientX + w3cDom.scrollLeft) || document.body.scrollLeft,
                    'y': eventObject.pageY || (eventObject.clientY + w3cDom.scrollTop) || doucument.body.scrollTop
                };
            }

    示例3:

           将连字符型字符串变为驼峰型字符串

      示例代码:

            function camelize(str) {
                return str.replace(/-(w)/g, function (allMathches, part1) {
                    return part1.toUpperCase();
                });
            }

            alert(camelize('s-a-ad-ee'));

            =>  sAAdEe

    示例4:

      将驼峰型字符串变为连字符型字符串

      示例代码:

            function unCamelize(str) {
                return str.replace(/([A-Z])/g, function (allMathes, part1) {
                    return '-' + part1.toLowerCase();
                });
            }      

    示例5:

            得到节点类名

            示例代码:

            String.prototype.trim = function () {
                return this.replace(/^s+|s+$/g, '');
            };
            function getClassName(element){
                return element.className.replace(/s+/g, ' ').trim().split(' ');
            }
            var arr = getClassName(document.getElementById('ceshi'));
            for (var i = 0; i < arr.length; i++) {
                console.log(arr[i]);
            }

    示例6:

      判定某节点是否含有某类名

      示例代码:

            function hasClassName (element, className) {
                if (!(element = $(element))) {
                    return false;
                }
                var classArr = getClassName(element);
                for (var i = 0; i < classArr.length; i++) {
                    if (classArr[i] === className) {
                        return true;
                    }
                }
                return false;
            }

    示例7:

      关于值传递,共享对象

      示例代码:

            var arr = [3, 5, 55, 25];
            var len = arr.length;
            alert(arr.length);
            arr.splice(1, 1);
            alert(arr.length);
            alert(len);

       =>  4

       =>  3

       =>  4

    示例8:

      增加类名

      示例代码:

            function addClassName(element, className) {
                if (!(element = $(element))) {
                    return false;
                }
                if (element.className) {
                    element.className += (element.className ? ' ' : '') + className;
                }
                return true;
            }

    示例9:

      删除类名

      示例代码:

            function removeClassName(element, className) {
                if (!(element = $(element))) {
                    return false;
                }
                var classArr = getClassName(element);
                var len = classArr.length;
                for (var i = (len - 1), i >= 0; i--) {
                    if (classArr[i] === className) {
                        arr.splice(i, 1);
                    }
                }
                return (len === arr.length) ? false : true;
            } 

    示例10

      设置节点样式

      示例代码:

            function setStyle(element, styles) {
                if (!(element = $(element))) {
                    return false;
                }
                for (property in styles) {
                    if (styles.hasOwnProperty(property)) {
                        if (element.style.setProperty) {
                            element.style.setProperty(unCamelize(property), styles[property], null);  //第三个参数,设置优先级
                        } else {
                            element.style[camelize(property)] = styles[property];
                        }
                    }
                }
            }

    示例11

      获得节点某样式

      示例代码:

            function getStyle(element, property) {
                if (!(element = $(element))) {
                    return false;
                }
                var value = element.style[camelize(poperty)];
                if (!value) {
                    if (document.defaultView && document.defaultView.getComputedStyle) {
                        var css = document.defaultView.getComputedStyle(element, null);  //第二个参数代表伪类
                        value = (css ? css.getPropertyValue(property) :null);
                    } else if (element.currentStyle) {
                        value = element.currentStyle[camelize(property)];
                    }
                }
                return value === 'auto' ? '' : value;
            }
           

      

     

         

  • 相关阅读:
    iOS应用崩溃日志分析
    使用Crashlytics来保存应用崩溃信息
    Mac和iOS开发资源汇总
    简单配置PonyDebugger
    程序员的工作不能用“生产效率”这个词来衡量
    使用Reveal 调试iOS应用程序
    MySQL 笔记
    flex弹性布局
    回调函数
    微信小程序开发
  • 原文地址:https://www.cnblogs.com/bugong/p/4280035.html
Copyright © 2011-2022 走看看