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的一些有用函数记录,不断更新。。。的更多相关文章

  1. PHP,JavaScript,CSS三种HTML内嵌语言的语法,变量,循环,函数记录

    PHP PHP简介: PHP 是服务器端脚本语言. PHP(全称:PHP:Hypertext Preprocessor,即"PHP:超文本预处理器")是一种通用开源脚本语言. PH ...

  2. 《Javascript高级程序设计》阅读记录(三):第五章 上

    这个系列以往文字地址: <Javascript高级程序设计>阅读记录(一):第二.三章 <Javascript高级程序设计>阅读记录(二):第四章 这个系列,我会把阅读< ...

  3. 《Javascript高级程序设计》阅读记录(七):第七章

    <Javascript高级程序设计>中,2-7章中已经涵盖了大部分精华内容,所以摘录到博客中,方便随时回忆.本系列基本完成,之后的章节,可能看情况进行摘录. 这个系列以往文字地址: < ...

  4. 《Javascript高级程序设计》阅读记录(六):第六章 下

    这个系列以往文字地址: <Javascript高级程序设计>阅读记录(一):第二.三章 <Javascript高级程序设计>阅读记录(二):第四章 <Javascript ...

  5. JavaScript的sleep延时函数

    JavaScript没有像Java的sleep延时函数,所以记录JavaScript的sleep延时函数 function sleep(milliSeconds) { var startTime = ...

  6. JavaScript的几种函数的结构形式

    匿名函数,普通函数,变量函数,基于对象的方法 介绍它们的优劣点(性能,执行条件,可维护性,适合大型还是小型) Javascript有着灵活多变的函数方法,具体选用何种形式,都会极大地影响应用程序的编写 ...

  7. 黄聪:mysql 存在该记录则更新,不存在则插入记录的sql

    一条mysql教程 存在该记录则更新,不存在则插入记录的sql , ‘yourname') ON DUPLICATE KEY UPDATE auto_name='yourname' ON DUPLIC ...

  8. javascript世界一等公民—函数

    简介 在很多传统语言(C/C++/Java/C#等)中,函数都是作为一个二等公民存在,你只能用语言的关键字声明一个函数然后调用它,如果需要把函数作为参数传给另一个函数,或是赋值给一个本地变量,又或是作 ...

  9. (转载)mysql 存在该记录则更新,不存在则插入记录的sql

    (转载)http://www.codesky.net/article/201003/105754.html 代码如下: INSERT table (auto_id, auto_name) values ...

随机推荐

  1. putty ssh 证书登录及问题

    1.用PUTTYGEN.exe生成密钥,生成的时候鼠标在进度条下面的空白处移动,为什么?就理解成随机得厉害点吧. 2.保存私钥,请看下面的图片说明 3.把公钥的内容想办法放到用户目录的.ssh/aut ...

  2. ESXi 5.1 识别GPT问题

    使用paredUtil命令 partedUtil mklabel /dev/disks/eui.227c000155707e0b msdospartedUtil mklabel /dev/disks/ ...

  3. 安装nodejs 后运行 npm 命令无响应

    安装和卸载过nodejs, 也编辑过 C:\Users\{账户}\下的.npmrc文件. 再全新安装nodejs ,运行npm 命令,无响应. 处理方法,删除C:\Users\{账户}\下的.npmr ...

  4. 基于SAR对Linux资源的监控shell脚本

    #! /bin/bash ] # $# 传递给脚本或函数的参数个数 then 脚本名称 exit -; fi SLEEP_TIME=$ LOG=$ while true do #线程数 thread_ ...

  5. JVM 内存溢出(转载~)

    对于JVM的内存写过的文章已经有点多了,而且有点烂了,不过说那么多大多数在解决OOM的情况,于此,本文就只阐述这个内容,携带一些分析和理解和部分扩展内容,也就是JVM宕机中的一些问题,OK,下面说下O ...

  6. 003-tomcat配置文件-server、tomcat-users

    1.server.xml讲解 位于conf下 <?xml version="1.0" encoding="UTF-8"?> <!-- Serv ...

  7. 跨平台编程相关技术资料及笔记.md

    目录 跨平台编程技术选型 ## 需求 最终选定的技术方案:uni-app 混合或跨平台编程相关资料 ## uni-app 官网 相关资料 个人笔记 个人经验 ## taro 官网 相关资料 ## Ch ...

  8. 一百零七:CMS系统之权限和角色模型定义

    模型与权限关系映射表 class CMSPersmission: """ 权限管理映射 """ # 255的二进制方式来表示 1111 11 ...

  9. postgres serial创建自增列

    Sequence是数据库中一类特殊的对象,其用于生成唯一数字标识符.一个典型的应用场景就是手动生成一系列主键.Sequence和MySQL中的AUTO_INCREMENT的概念很像. 创建序列Sequ ...

  10. centos7.6安装docker

    先运行 yum update 然后卸载旧版本 yum remove docker \ docker-client \ docker-client-latest \ docker-common \ do ...