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;
}
2015-02-08——js笔记的更多相关文章
- 02: vue.js常用指令
目录:Vue其他篇 01: vue.js安装 02: vue.js常用指令 目录: 1.1 vuejs简介 1.2 选择器:根据id.class等查找 1.3 静态绑定数据 data 1.4 插值 { ...
- Data Visualization and D3.js 笔记(1)
课程地址: https://classroom.udacity.com/courses/ud507 什么是数据可视化? 高效传达一个故事/概念,探索数据的pattern 通过颜色.尺寸.形式在视觉上表 ...
- js笔记-0
#js笔记-0 数组: indexOf方法: Array也可以通过indexOf()来搜索一个指定的元素的位置: var arr = [10, 20, '30', 'xyz']; arr.indexO ...
- Storm(2015.08.12笔记)
2015.08.12Storm 一.Storm简介 Storm是Twitter开源的一个类似于Hadoop的实时数据处理框架. Storm能实现高频数据和大规模数据的实时处理. 官网资料显示s ...
- Zookepper(2015.08.16笔记)
2015.08.16zookepper Zookeeper 是 Google 的 Chubby一个开源的实现,是 Hadoop 的分布式协调服务(如同小区里面的供水.电的系统) 它包含一个简单的原 ...
- Node.js 笔记02
一.关于命令 常用命令: dir 列出当前目录下面所有的文件 cd 目录名 进入到指定的目录,. 当前目录, .. 进入上级目录,cd . 当前目录, cd .. 上级目录 md 目录名 创建文件夹 ...
- 2015年10月23日JS笔记
ECMAScript标准:JavaScript核心语法 微软:Jscript ECMAScript标准:一纸空文 JavaScript和JScritp都号称完全实现了 ECMAScript标准 W3C ...
- JS笔记—02
1.String截取:substr:截几位, substring:截到哪. 2.String的操作,例如变大写,小写,本身不会变,只是在栈里交换引用似的 var str = "hello w ...
- iOS 学习笔记 二 (2015.02.26)
How To Use Git Source Control with Xcode in iOS 6 If you're new here, you may want to subscribe to m ...
- iOS 学习笔记 一 (2015.02.05)
一:Xcode6输入框设置为 keyboard type设置为Number Pad弹不出键盘的解决办法 问题:Can't find keyplane that supports type 4 fo ...
随机推荐
- JavaScript 事件循环及异步原理(完全指北)
引言 最近面试被问到,JS 既然是单线程的,为什么可以执行异步操作? 当时脑子蒙了,思维一直被困在 单线程 这个问题上,一直在思考单线程为什么可以额外运行任务,其实在我很早以前写的博客里面有写相关的内 ...
- PullToRefresh使用详解(一)--构建下拉刷新的listView
前言:前几天写了篇关于PullToRefresh控件的DEMO导入的博客,但由于当时没有用到,所以就没细往下讲,现在开始到了实战阶段,用到了PullToRefresh的listView样式,网上有讲的 ...
- set hive.exec.parallel
hive.exec.parallel参数控制在同一个sql中的不同的job是否可以同时运行,默认为false.下面是对于该参数的测试过程: 测试sql:select r1.a from (sel ...
- PE下挂载注册表文件然后清除系统托盘空白图标缓存
清除了右下角通知栏图标缓存TrayNotify(否则会出现一堆空白图标)清除缓存批处理脚本.bat如何在PE系统环境下清除宿主系统的托盘图标缓存? 清除了右下角通知栏图标缓存TrayNotify(否则 ...
- MII_GMII_RGMII_RMII_SMII_SSMII_TBI_RTBI比较
MII_GMII_RGMII_RMII_SMII_SSMII_TBI_RTBI比较 https://wenku.baidu.com/view/2e136caa8bd63186bdebbc40.html
- C++语言基础(16)-string类
使用 string 类需要包含头文件<string>,下面的例子介绍了几种定义 string 变量(对象)的方法: #include <iostream> #include & ...
- C/C++ 错误笔记-如果要释放内存,必须拿到内存的首地址进行释放
例:修改字符串的第三个字母为a #include <stdlib.h> #include <string.h> #include <stdio.h> #pragma ...
- ulimit调优|设置普通用户的ulimit值
个人总结: 如何设置普通用户的ulimit值 1.vim /etc/profile 增加 ulimit -n 10240 source /etc/profile 重新启动就不需要运行这个命令了. 2. ...
- Vim使用技巧(3) -- 可视化模式技巧 【持续更新】
快捷键 Esc / Ctrl + [ / v //切换到普通模式 o //切换高亮选区的光标活动端 y //将光标选中的内容复制到寄存器中 u //将光标选中的字母全部改成小写字母 U //将光标选中 ...
- easyui最简单的左右布局实现,及tab的右键菜单实现
发现最近有些人问用JQuery easyui要怎么实现左右结构的布局.就是点击左边的菜单在右边的tab中打开.其实easyui要实现这种布局很简单,只需要简单的几行代码就ok了. 特意做了一个小小的d ...