//获取元素属性

function getStyle(obj, attr) {

return obj.currentStyle ? obj.currentStyle[attr] : getComputedStyle(obj, 0)[attr];

}

//运动函数

function doMove(obj, attr, speed, target, endFn) {

clearInterval(obj.timer);

speed = parseInt(getStyle(obj, attr)) < target ? speed : -speed;

//alert(speed);

obj.timer = setInterval(function () {

var curPosition = parseInt(getStyle(obj, attr)) + speed;

if (curPosition > target && speed > 0 || curPosition < target && speed < 0)

curPosition = target;

obj.style[attr] = curPosition + 'px';

if (curPosition == target) {

clearInterval(obj.timer);

endFn && endFn();

}     }, 50); }

//抖动函数

//透明度渐变函数

//需找与数组相等的值函数

function arrIndexOf(arr, v) {

for (i = 0; i < arr.length; i++) {

if (arr[i] == v) {

return i; //返回与目标值相等的数组的下标值

}

}

return -1;

}

//getElementByClassName函数

function getElementByClassName(parent, tagName, className) {

var aEls = parent.getElementsByTagName(tagName);

var arr = [];

for (var i = 0; i < aEls.length; i++) {

var arrClassName = aEls[i].className.split(' ');

var _index = arrIndexOf(arrClassName, className);

if (_index != -1) {

arr.push(aEls[i]);

}

}

return arr;

}

//addClass函数

function addClass(obj, className) {

if (obj.className == '') {

//如果原来没有class

obj.className = className;

}

else {

var arrClassName = obj.className.split(' ');

var _index = arrIndexOf(arrClassName, className);

if (_index == -1) {

//如果要添加的class在原来的class中不存在

obj.className += ' ' + className;

}

//如果要添加的class在原来的class中存在,则不需要做任何事

}

}

//removeClass函数

function removeClass(obj, className) {

//如果原来有class

if (obj.className != '') {

var arrClassName = obj.className.split(' ');

var _index = arrIndexOf(arrClassName, className);

if (_index != -1) {

arrClassName.splice(_index, 1);  //删除需要删除的calss

obj.className = arrClassName.join(' '); //然后将arrClassName数组拼接起来

}

}

}

//绑定事件函数

function bind(obj, evname, fn) {

if (obj.addEventListener) {

obj.addEventListener(evname, fn, false);

} else {

obj.attachEvent('on' + evname, function () {

fn.call(obj);             //fn()==fn.call()  call(第一个参数,第二个参数) call函数可以改变函数this的指向,call函数传入的第一个参数就是改变this指向的值,call的第二第三个参数就是原函数的参数

});

}

}

//鼠标在可视区域内的拖拽 不兼容非标准IE

function clientDrag(obj) {

obj.onmousedown = function (ev) {

ev = ev || event;

var ms_b = ev.clientX - obj.offsetLeft;

var ms_t = ev.clientY - obj.offsetTop;

document.onmousemove = function (ev) {

ev = ev || event;

var currX = ev.clientX - ms_b;

var currY = ev.clientY - ms_t;

var Width = document.body.clientWidth || document.documentElement.cilentWidth;

var Height = document.body.clientHeight || document.documentElement.cilentHeight;

if (currX < 0) { currX = 0; }

else if (currX > Width - obj.clientWidth) {

currX = Width - obj.clientWidth;

}

if (currY < 0) { currY = 0; }

else if (currY > Height - obj.clientHeight) {

currY = Height - obj.clientHeight;

}

obj.style.left = currX + 'px';

obj.style.top = currY + 'px';

return false;

}

document.onmouseup = function () {

document.onmousemove = document.onmouseup = null;

}

}

}

一些常用的JS函数的更多相关文章

  1. 工作中常用的JS函数整理分享(欢迎大家补充)

    今年在渣X工作整理的常用JS函数 今年来了渣X工作,我所在这个部门分工很奇怪,CSS竟然有专门的人在搞,开发PHP的人员需要处理JS,以至于有时候开发起来不是那么得心应手,感觉把JS和CSS拆开就像是 ...

  2. 常用原生JS函数和语法集合

    luoyishan-2017-10-08 1. 输出语句:document.write(""); 2. JS中的注释为// 3. 传统的HTML文档顺序是:document-> ...

  3. 常用的js函数

    function $(){ return document.getElementById(arguments[0])}; /** * 得到上一个元素 * @param {Object} elem */ ...

  4. 100多个基础常用JS函数和语法集合大全

    网站特效离不开脚本,javascript是最常用的脚本语言,我们归纳一下常用的基础函数和语法: 1.输出语句:document.write(""); 2.JS中的注释为//3.传统 ...

  5. (转)在网页中JS函数自动执行常用三种方法

    原文:http://blog.sina.com.cn/s/blog_6f6b4c3c0100nxx8.html 在网页中JS函数自动执行常用三种方法 在网页中JS函数自动执行常用三种方法 在HTML中 ...

  6. 原生JS研究:学习jquery源码,收集整理常用JS函数

    原生JS研究:学习jquery源码,收集整理常用JS函数: 1. JS获取原生class(getElementsByClass) 转自:http://blog.csdn.net/kongjiea/ar ...

  7. api日常总结:前端常用js函数和CSS常用技巧

    我的移动端media html{font-size:10px} @media screen and (min-width:321px) and (max-width:375px){html{font- ...

  8. web前端关于html转义符的常用js函数

    web前端关于html转义符的常用js函数 //去掉html标签 function removeHtmlTab(tab) { return tab.replace(/<[^<>]+? ...

  9. 基础常用JS函数和语法

    100多个基础常用JS函数和语法集合大全  来源:http://www.cnblogs.com/hnyei/p/4605103.html 网站特效离不开脚本,javascript是最常用的脚本语言,我 ...

随机推荐

  1. Long,String类型的两个值进行比较,注意点!!!

    一: . Long 类型指的是 java.util.Lang 对象,而不是基本类型 long (注意大小写)Java中如果使用 == 双等于比较对象,等于比较的是两个对象的内存地址,也就是比较两个对象 ...

  2. mysql模拟插入数据表

    由于测试或者学习需要,我们要经常向一个新建的数据表插入几百万行以上的数据来验证我们的一些想法,比如索引的合理构建,表字段类型的设计等等,下面跟大家演示如何往一个新建的数据表插入N多条数据. 1.新建一 ...

  3. bootstrap输入框从数据库读取数据

    https://github.com/lzwme/bootstrap-suggest-plugin

  4. JDBC之一:JDBC快速入门

    (1)下载Oracle的JDBC驱动,一般放在$ORACLE_HOME/jdbc/lib目录,关于驱动的版本请见: http://elf8848.iteye.com/blog/811037 随Orac ...

  5. 切记ajax中要带上AntiForgeryToken防止CSRF攻击

    在程序项目中经常看到ajax post数据到服务器没有加上防伪标记,导致CSRF被攻击,下面小编通过本篇文章给大家介绍ajax中要带上AntiForgeryToken防止CSRF攻击,感兴趣的朋友一起 ...

  6. js Array 学习

    摘抄自<JavaScript权威指南> 1.join()返回生成的字符串.数组元素转化为字符串,拼接.默认分隔符:“,”. 2.reverse()返回逆序的数组,替换.数组中的元素倒序. ...

  7. Python zxing 库解析(条形码二维码识别)

    各种扫码软件 最近要做个二维码识别的项目,查到二维码识别有好多开源的不开源的软件 http://www.oschina.net/project/tag/238/ Zbar 首先试了一下Zbar,pyt ...

  8. mac osx 10.9 ftp server端口

    开启 FTP Serversudo -s launchctl load -w /System/Library/LaunchDaemons/ftp.plist 关闭 FTP Serversudo -s ...

  9. virtual box Failed to load unit ""pgm" 的error

    原因:没有正常的待机或者关机退出. 解决办法:右键清除保存状况.

  10. 使用jquery处理ajax返回XML

    JS代码: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 3 ...