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;
        }
       

  

 

     

原文地址:https://www.cnblogs.com/bugong/p/4280035.html