javascript的一些有用函数记录,不断更新。。。
addLoadEvent函数:
众所周知,html文档加载完后会立即执行一个onload函数。但是onload函数只能包含一个被执行的函数,也就是你需要在加载完文档后执行的一个自己的函数。在实际中html加载完成后需要执行很多预先执行的函数,那么怎样才能让html文档加载完后执行很多自己的函数呢?
1. 最简单的方法:回调
window.onload = function(){
function1();
function2();
}
2.另一种解决办法:
function addLoadEvent(func){
var oldonload = window.onload;
if(typeof oldonload != 'function'){
window.onload = func();
}else{
window.onload = function(){
oldonload();
func();
}
}
}
然后再js脚本里执行:
addLoadEvent(function1);
addLoadEvent(function2);
......
它就会在html加载完成后自动的执行window.onload。 其实这个函数和上一个简化版本的功能是一样的。 只不过简化版本需要修改函数内部数据,在需要预加载函数过多的情况下容易写错函数名,造成加载错误。而第二个函数只需要调用函数并传参就可以了。不必动用函数内部造成不必要的错误。
--------------------------------------------------------分割线-------------------------------------------------------------------------
insertAfter函数:
DOM虽然提供了insertBefore函数,用于在已有元素前插入一个新元素,但是DOM没有提供相应的方法在已有元素后插入一个新元素的方法。 所以需要自己编写一个函数,来处理这项工作:
函数如下:
function insertAfter(newElement,targetElement){
var parent = targetElement.parentNode;
if(parent.lastChild == targetElement){
parent.appentChild(newElement);
}else{
parent.insertBefore(newElement,targetElement.nextSibling);
}
}
这个函数不用过多解释了,一目了然!
--------------------------------------------------------分割线-------------------------------------------------------------------------
用js为html表格设置跨行颜色
function setTablesColor(){
var tables = document.getElementsByTagName("table");
var odd,rows;
for(var i = 0; i < tables.length; i++){
odd = false;
rows = tables[i].getElementsByTagName("tr");
for(var j = 0; j < rows.length; j++){
if(odd == true){
rows[j].style.backgroundColor = "#ffc";
odd = false;
}else{
odd = true;
}
}
}
}
这个函数无论页面中有多少个表格,都可以统一进行颜色的跨行设置,而不必通过对每个table元素设置class来设置颜色。特别是表格数据量很大的情况下,用js函数设置省时省力。
--------------------------------------------------------分割线-------------------------------------------------------------------------
接下来这个函数,比较当前链接的URL与当前页面的URL是否相同,如果相同,则给当前链接的a元素添加一个类,css依靠这个类设置了一个背景颜色,使其突出显示。 或者也可以这样,如果当前链接URL和当前页面URL相同,则css用display:none;不显示当前元素。
函数如下:
function highlightPage(){
if(!document.getElementsByTagName) return false;
if(!document.getElementById) return false;
//nav元素包含在header元素中,先找到header元素
var headers = document.getElementsByTagname('header');
if(headers.length == 0) return false;
//再找到nav元素里的a元素
var navs = headers[0].getElementsByTagName('nav');
if(navs.length == 0) return false;
//取得导航链接,然后循环它们
var links = navs[0].getElementsByTagName('a');
var linkurl;
for(var i=0; i<navs.length; i++){
//要比较当前链接的URL与当前页面的URL。要取得链接的URL,用getAttribute('href')
//而要取得当前页面的URL,则可以使用window.location.href
//用indexOf方法,查找子字符串在字符串中的位置,如果没有匹配到,则indexOf方法返回-1
linkurl = links[i].getAttribute('href');
if(window.location.href.indexOf(linkurl) != -1){
links[i].className = 'here';
//给每一个链接添加一个here类
}
}
}
javascript的一些有用函数记录,不断更新。。。的更多相关文章
- PHP,JavaScript,CSS三种HTML内嵌语言的语法,变量,循环,函数记录
		
PHP PHP简介: PHP 是服务器端脚本语言. PHP(全称:PHP:Hypertext Preprocessor,即"PHP:超文本预处理器")是一种通用开源脚本语言. PH ...
 - 《Javascript高级程序设计》阅读记录(三):第五章 上
		
这个系列以往文字地址: <Javascript高级程序设计>阅读记录(一):第二.三章 <Javascript高级程序设计>阅读记录(二):第四章 这个系列,我会把阅读< ...
 - 《Javascript高级程序设计》阅读记录(七):第七章
		
<Javascript高级程序设计>中,2-7章中已经涵盖了大部分精华内容,所以摘录到博客中,方便随时回忆.本系列基本完成,之后的章节,可能看情况进行摘录. 这个系列以往文字地址: < ...
 - 《Javascript高级程序设计》阅读记录(六):第六章 下
		
这个系列以往文字地址: <Javascript高级程序设计>阅读记录(一):第二.三章 <Javascript高级程序设计>阅读记录(二):第四章 <Javascript ...
 - JavaScript的sleep延时函数
		
JavaScript没有像Java的sleep延时函数,所以记录JavaScript的sleep延时函数 function sleep(milliSeconds) { var startTime = ...
 - JavaScript的几种函数的结构形式
		
匿名函数,普通函数,变量函数,基于对象的方法 介绍它们的优劣点(性能,执行条件,可维护性,适合大型还是小型) Javascript有着灵活多变的函数方法,具体选用何种形式,都会极大地影响应用程序的编写 ...
 - 黄聪:mysql 存在该记录则更新,不存在则插入记录的sql
		
一条mysql教程 存在该记录则更新,不存在则插入记录的sql , ‘yourname') ON DUPLICATE KEY UPDATE auto_name='yourname' ON DUPLIC ...
 - javascript世界一等公民—函数
		
简介 在很多传统语言(C/C++/Java/C#等)中,函数都是作为一个二等公民存在,你只能用语言的关键字声明一个函数然后调用它,如果需要把函数作为参数传给另一个函数,或是赋值给一个本地变量,又或是作 ...
 - (转载)mysql 存在该记录则更新,不存在则插入记录的sql
		
(转载)http://www.codesky.net/article/201003/105754.html 代码如下: INSERT table (auto_id, auto_name) values ...
 
随机推荐
- Codeforces 1009 E. Intercity Travelling(计数)
			
1009 E. Intercity Travelling 题意:一段路n个点,走i千米有对应的a[i]疲劳值.但是可以选择在除终点外的其余n-1个点休息,则下一个点开始,疲劳值从a[1]开始累加.休息 ...
 - 关于keepalive
			
linux内核配置有一项tcp_keepalive_time,即tcp的保活定时器.当网络上两个建立连接的进程都没有数据向对方发送的时候,tcp会隔段时间发送一次保活数据,以保持连接,间隔时间就是tc ...
 - linux服务器上生成CSR和KEY
			
CSR表示“ 证书签名请求 ”,这个该证书将用于服务器上.一个CSR包含有关您的组织和域名,地方和国家,将包含在证书中的公钥信息. 本文有3个简单的步骤来创建CSR上的Linux系统(证书签名请求). ...
 - moveLeft()
			
这里大致都和上面一样,就是在记录左边坐标时,应该应该是lx = x - 1. void moveLeft(){ //定义变量存放人物左边的坐标 int lx, ly; //当左边没有元素时,直接ret ...
 - 利用JDK自带工具监控JVMCPU和内存指标
			
特别提示:本人博客部分有参考网络其他博客,但均是本人亲手编写过并验证通过.如发现博客有错误,请及时提出以免误导其他人,谢谢!欢迎转载,但记得标明文章出处:http://www.cnblogs.com/ ...
 - 第十四周课程总结&实验报告(简单记事本的实现)
			
1.JDBC概述 JDBC提供了一种与平台无关的用于执行SQL语句的标准JavaAPI,可以方便的实现多种关系型数据库的统一操作,它由一组用Java语言编写的类和接口组成 主要常用操作类与接口: ja ...
 - linux 下安装redis并用QT写客户端程序进行连接
			
1.安装redis.使用如下命令: wget http://dowload.redis.io/redis-stable.tar.gz tar xzf redis-stable.tar.gz cd ...
 - Android 网络请求Retrofit + RxJava
			
一.背景 经常看到项目用Retrofit+RxJava+RxAndroid的框架,为了看懂项目的结构.现在来了解一下,Retrofit: Retrofit是Square 公司开发的一款正对Androi ...
 - Android自定义权限与使用
			
1. 如何自定义权限 Android允许我们使用permission标签,在Manifest文件中定义属于自己的权限,一个例子如下, <?xml version="1.0" ...
 - LC 973. K Closest Points to Origin
			
We have a list of points on the plane. Find the K closest points to the origin (0, 0). (Here, the d ...