当前位置: 代码迷 >> JavaScript >> javascript常识汇总
  详细解决方案

javascript常识汇总

热度:396   发布时间:2012-07-15 20:20:06.0
javascript知识汇总

javascript知识汇总
2010年07月08日
  在数百万张页面中,JavaScript 被用来改进设计、验证表单、检测浏览器、创建cookies,等等等等。
  JavaScript 是因特网上最流行的脚本语言,并且可在所有主要的浏览器中运行,比方说 Internet Explorer、 Mozilla、Firefox、Netscape、和 Opera。
  什么是 JavaScript?
  JavaScript 被设计用来向 HTML 页面添加交互行为。
  JavaScript 是一种脚本语言(脚本语言是一种轻量级的编程语言)。
  JavaScript 由数行可执行计算机代码组成。
  JavaScript 通常被直接嵌入 HTML 页面。
  JavaScript 是一种解释性语言(就是说,代码执行不进行预编译)。
  所有的人无需购买许可证均可使用 JavaScript。
  JavaScript 能做什么?
  JavaScript 为 HTML 设计师提供了一种编程工具
  HTML 创作者往往都不是程序员,但是 JavaScript 却是一种只拥有极其简单的语法的脚本语言!几乎每个人都有能力将短小的代码片断放入他们的 HTML 页面当中。
  JavaScript 可以将动态的文本放入 HTML 页面
  类似于这样的一段 JavaScript 声明可以将一段可变的文本放入 HTML 页面:document.write("" + name + "")
  JavaScript 可以对事件作出响应
  可以将 JavaScript 设置为当某事件发生时才会被执行,例如页面载入完成或者当用户点击某个 HTML 元素时。
  JavaScript 可以读写 HTML 元素
  JavaScript 可以读取及改变 HTML 元素的内容。
  JavaScript 可被用来验证数据
  在数据被提交到服务器之前,JavaScript 可被用来验证这些数据。
  JavaScript 可被用来检测访问者的浏览器
  JavaScript 可被用来检测访问者的浏览器,并根据所检测到的浏览器,为这个浏览器载入相应的页面。
  JavaScript 可被用来创建 cookies
  JavaScript 可被用来存储和取回位于访问者的计算机中的信息。
  教程地址: 
  http://www.w3school.com.cn/js/js_intro.asp
  
  ....
  //-->
   .language已经被弃用,但为了兼容旧版本浏览器而保留,所以建议同时使用这language和type两个
  .     的作用是使得不支持JavaScript的旧版本浏览器能忽略脚本内容
  .
  charset单独设置 xxx.js的字符编码
  .利用DOM实现
  document.body.onload=function(){
  alert("xxxx");
  }
  .变量
  命名规则
  可以由字母、下划线_、数字、$组成
  必须以字母、下划线_、或$开头
  变量名不能是关键字或保留字
  推荐使用骆驼型命名法
  可以使用var来声明变量,但一定要在使用之前声明
  var a,b=1,c;
  a=2;
  c=4;
  也可以不经过var声明而直接使用,这样和上面没有任何区别,只是会降低可读性
  JavaScript是大小写敏感的
  变量类型
  undefined      未定义
  null           空
  boolean        布尔
  string         字符串
  number         数值
  object         对象
  var a="ddddd";
  if("string" == typeof(a))
  {
  alert("==");
  }
  var b=false;
  if("boolean" == typeof(b))
  {
  alert("==");
  }
  var f=null;     //typeof(f) == "object"
  if("undifined" == typeof(x))
  {
  alert("==");
  }
  类型转换
  undefined、null、0、NaN、""          都为false
  object                             总为true
  强制转换成数字型
  var b="33";
  b+67;      //3367
  parseInt(b)+67; //100
  parseFloat("333.98");
  判断是否非数字 isNaN()
  var a="xxxx";
  alert(isNaN(a));     //true
  判断一个数是否不是无穷大 isFinite()
  var a=22;
  alert(isFinite(a));     //true
  判断是否润年
  function isLeapYear(year_)
  {
  var year=parseInt(year_);
  //if((0==year%400) || (0==year%4) && (0!=year%100)) { //... }
  if(0 == year%400)     //能被400整除是
  return true;
  elseif(0==year%4 && 0!=year%100) //
  return true;
  else
  return false;
  }
  .switch()
  switch(exp)
  {
  case 1:
  case 2:
  case 3:
  //...
  break;
  case 4:
  //...
  break;
  default:
  //...
  break;
  }
  .for
  for(var i=0; i++; i...
  }
  .将函数赋给一个变量或事件
  doucment.body.onload = function(){
  alert("load);
  }
  var max = function(a,b){
  return     (a)>(b)?(a):(b);
  }
  则可以通过max执行函数 max(4,5);      //5
  var global=123;     //全局变量
  function abc()
  {
  var local=global;     //局部变量local用全局变量global赋值
  }
  .eval(string)函数
  执行把参数string所表示的命令
  var act="alert('ssssss')";
  eval(act);      //将执行alert("ssss")
  .对url进行编码
  escape(url);
  unescape(url);
  .日期
  var objDate = new Date("January 12,2006 22:19:34");
  var objDate = new Date("January 12,2006");
  var objDate = new Date(2006,1,12,22,19,34);
  var objDate = new Date(2006,1,12);
  var objDate = new Date(1177663004);     //自1970年来的秒数
  objDate.getFullYear();
  objDate.getYear();
  objDate.getMonth();
  objDate.getDate();
  objDate.getDay();
  objDate.getHours();
  objDate.getMinutes();
  objDate.getSeconds();
  objDate.getMilliseconds();
  objDate.getTime();         //返回从1970年来的毫秒数
  objDate.setFullYear(2007);
  objDate.setYear(07);
  objDate.setMonth(12);
  objDate.setDate(11);
  objDate.setHours(23);
  objDate.setMinutes(34);
  objDate.setSeconds(56);
  objDate.setMilliseconds(555);     //0~999
  objDate.setTime(1180195200000);         //返回从1970年来的毫秒数
  .Math
  Math.E
  Math.PI
  Math.abs(x)
  Math.ceil(x)
  Math.floor(x)
  Math.max(a,b,c,...,valN)
  Math.min(a,b,c,...,valN)
  Math.pow(x,y)     //x的y次方
  Math.random()     //0~1之间的随机小数如 0.123535464
  Math.round(78.67)     //四舍5入
  .数组
  var arr = new array();
  var arr = new array(10);
  var arr = new array("a","b","c");
  var arr = new array();
  arr[]="1";
  arr[]="2";
  arr[]="3";
  ..
  arr[9]="290";
  arr[]="14";
  .多维数组
  var arr = new Array(4);
  for(var i=0; i...); //var arr=[1,2,3];     arr.concat("4","5","6");     //返回 1,2,3,4,5,6 而arr不受影响
  arr.join(separator);                 //以separator为分隔符, 把数组转成字符串
  arr.pop();                           //删除数组最后一个元素
  arr.push(arg1,arg2,arg3,....)        //把arg1,arg2等等添加到数组尾部
  arr.shift();                         //删除第一元素
  arr.slice(start, end);               //返回数组中下标从start到end间的子数组
  arr.sort(comparefunc);               //对数组进行按func函数结果的排序
  arr.unshift(arg1,arg2,...)           //把arg1,arg2等元素添加到数组头部
  arr.splice(start, nums, arg1,arg2,...);      //把从start开始的nums个元素替换成 arg1,arg2,..., 而不是对应替换
  arr = [1,2,3,4,5,6];
  arr.splice(0,0,9,22,33);             // arr=[9,22,33,1,2,3,4,5,6]
  arr.splice(1,3,9,22,33);             // arr=[1,9,22,33,5,6]     把第1个到第3个元素2,3,4替换成9,22,33
  .string字符串
  var str="123456";
  字符串长度
  str.length
  str.indexOf(substring,pos);      //"abcdef".indexOf("bc",1);      返回子串bc在串"abcdef"中的第一次出现下标
  str.lastIndexOf(substring,pos);      //"abcdef".indexOf("bc",1);      返回子串bc在串"abcdef"中的最后一次出现下标
  str.charAt(pos);                  //返回下标pos处的单个字符
  str.charCodeAt(pos);              //返回下标pos处的字符的ASCII码
  str.slice(start, end);            //返回从start到end之间的子串(不包含end处字符)
  str.split(separator, len);     //把串str以separator为分隔符切割成多个子符串数组,子串数组的最大长度
  //"a,b,c,d".split(",") 返回["a","b","c","d"]
  //"a,b,c,d".split(",", 2) 返回["a","b"]
  //"a,b,c,d".split() 返回["a,b,c,d"]
  //"a,b,c,d".split("") 返回["a",",""b",",",c",",","d"]
  str.substr(start, length);     //返回从start处的长为length子串
  str.substring(start, end);     //返回从start到end之间的子串(包含end处字符)
  .字符串替换
  str.replace(oldsubstr, newsubstr);      //把串str中的oldsubstr子串替换为newsubstr子串 .字符串大小写转换
  str.toLowerCase();               //把串str转为小写
  str.toUpperCase();               //把串str转为大写
  .正则表达式匹配
  str.match(regExp)      搜索str中所有匹配正则表达式regExp的子串,并把他们组成一个数组返回
  var arr=str.match(/\d+/);
  for(var i=0; i= 0);
  }      function isFirefox()
  {
  return (navigator.userAgent.toLowerCase().indexOf("firefo x") >= 0);
  }      2)location对像
  window.location = "http://www.cnscn.org";
  window.location.href = "http://www.cnscn.org";
  window.location.assign("http://www.cnscn.org");      window.location.protocol           协议如 "http:"     (注意IE和firefox都要带:即冒号 "http:")
  window.location.hostname           域名或IP: www.a.com 或 192.168.1.1
  window.location.host
  window.location.pathname           如http://172.16.1.69/ajax/b.html?a=1&b=2 输出 /ajax/b.html
  window.location.search             如http://172.16.1.69/ajax/b.html?a=1&b=2 输出 ?a=1&b=2     (即带?号)
  window.location.href               如http://172.16.1.69/ajax/b.html?a=1        输出 http://172.16.1.69/ajax/b.html?a=1
  window.location.port
  window.location.hash
  window.location.reload(boolean)     参数为true表示强制从服务器重新载入, 为false表示从缓存中重新载入
  window.replace(url)                导航到url指定页面(和指定href相同),但在浏览历史中替换当前页地址(和指定url不同)
  3)history对象
  history.back();                    //相当于后退按钮
  history.forward();                 //相当于前进按钮
  history.go(-2);                    //相当于点击两次后退按钮
  4)document对象
  document.anchors                   //书签标记数组 document.anchors[0].name
  document.embeds                    //所有数组
  document.forms                     //所有表单数组            document.forms[0].action
  document.images                    //所有数组          document.images[0].offsetWidth     document.images[0].sttyle.width 
  document.links                     //所有数组       document.links[0].target
  document.cookie                    //返回或设置cookie 
  document.domain                    //返回或设置文档默认域名
  document.lastModified              //文档最后一次修改日期
  document.location                  //相当于window.location
  document.referrer                  //返回来源页面  
  document.title                     //返回或设置文档标题
  document.URL                       //返回或设置文档url
  5)with
  with(document){
  write(cookie);        //相当于 document.write(document.cookie)
  write("abc");
  write(URL);
  }
  .事件对象
  function sayHello()
  {
  alert("hello");
  }
  doucment.onclick = sayHello;     //把函数赋对对象事件
  document.getElementById('img1').onclick = sayHello;
  .attachEvent和addEventListener 方法绑定事件处理程序, 可以让一个事件有多个处理程序
  element.addEventListener("enventName", 函数名, boolean );      //boolean: true表示事件处理模式是使用捕获模式, false 表示否
  function func()
  {
  //...
  }
  if(element.addEventListener){
  element.addEventListener("onclick", func, false);
  }
  else
  {
  element.attachEvent("click", func, false);
  }
  .window.event对象     window可以省略,即使用event
  它是处理按键、光标位置、触发事件的对象
  IE:
  event对象是个全局对象
  function imgClick()
  {
  alert(event.srcElement.src);
  }
        //这样当点击图片时,就会产生event的相应属性或方法
  Mozilla:
  event对象必须被显式传递给事件处理程序, 因为它是当前局部对象而不是全局对像
  function imgClick(evt)
  {
  alert(evt.target.src);
  }
        //这样当点击图片时,就会产生event的相应属性或方法
  .event对象的属性
  IE                        Firefox
  srcElement               target                     触发事件的元素
  type                         type                       事件类型
  offsetX                      无                          元素的x坐标
  offsetY                      无                          元素的y坐标
  x                             layerX                     定位元素的x坐标
  y                             layerY                     定位元素的y坐标
  clientX                     clientX                    窗口的x坐标
  clientY                     clientY                     窗口的y坐标
  screenX                  screenX                   屏幕的x坐标
  screenY                  screenY                   屏幕的y坐标
  button                     button                      鼠标按键
  keyCode                 keyCode                 键盘按键
  shiftKey                   shiftKey                
  altKey                     altKey
  ctrlKey                    ctrlKey
  fromElement            relatedTarget         上一级元素
  toElement                relatedTarget         下一级元素
  
  
  //一定要放到
  .表单form
  var frm=document.forms["submitform"];
  var frm=document.forms[0];
  frm.action
  frm.elements
  frm.encoding
  frm.length
  frm.method
  frm.name
  frm.target
  frm.submit();
  frm.reset();
  onsubmit();
  onreset();
  frm.elements[0].type       //text submit password     select-one select-multiple
  frm.elements[0].disabled = true;     //false 创建只读表单域
  .
  
  
  
  onkeydown="func()"
  onkeyup()="func()"
  onkeypress()="func()"
  onmouseover()="func()"
  onmouseout()="func()"
  onmousedown()="func()"
  onmouseup()="func()"
  onchange()="func()"
  .使用select选中文本
  
  .text
  .删除一个option
  objSelect.options=null;
  .清空一个select
  
  0
  1
  2
  3
  4
  
  //正确清空方法
  //每一循环都删除第一个元素,当循环结束时,元素也删除完了
  //类似于栈的pop()即每次pop出栈顶即第一个元素
  for(var i=0; i<len; i++) 
  objSelect.options[0]=null;
  /*
  //错误方法1: 将留下options[1]和options[3]
  for(var i=0; i<len; i++)~~
  objSelect.options=null;
  //错误方法2: 将留下options[3]和options[4]
  for(var i=0; i<objSelect.length; i++)
  objSelect.options[0]=null;
  */  
  相关解决方案