javascript 笔记(1)
document.forms[0].names.value == ''
forms[0]表示文档的第一个 form 表单,names 表示这个表单元素名为 names 的表单的元素,此时表示的是获取此页面中,第一个表单中名称为 names 的值!
IE特有的,火狐没有
<script for="id/name" event="事件名(onclick)">
// 代码
</script>
用 var 声明的变量表示局部变量,用 var 声明的变量,可以先声明,不用赋值就可用,不会报错,而不用 var 声明的,必须赋值,不然会报错,推荐用 var 声明变量!
严格区分大小写,变量名可用驼峰法或者是首字母大字!
js 是面向对象的语言,却没有类的,所以不能用类的方式来实现,而是用面向对象的方式来实现,即 JSON(javascript object nonation) 格式,用 new 或者 {},如 var obj = new Object(); 或者 var obj = {};
函数声明方式:
1.声明方式
function 函数名([参数列表]){
// 代码
}
2.字面量定义方式:(匿名函数)
var 变量名 = function([参数列表]){
// 代码
}
调用时: 变量名([参数列表]);
3.以对象的形式声明:(少用)
var 变量名 = new Function([参数列表], "代码段");
此时的参数和代码段要用单/双引号,function首字母要大写!
也可以直接这样用:
(function(){代码})()
以基本语法声明的函数,会在代码运行时,提前加载到内存中,供以后使用,但是以字面量形式命名的函数,会在执行到的时候进行赋值,所以同名函数与此时的字面量定义的变量名相同时,总是执行字面量函数!
函数参数问题:
函数的形参与实参数量不一致时,不会报错,在函数中隐式创建一个 arguments 对象,它包含实际传入的参数的信息,引用时可用下标法,如 arguments[i],实际传入的参数有两个信息,一个为 length,一个为calle,calle 即对本身代码的描述!
函数调用方式:
1。通过指针形式来调用函数:
函数名是一个指针,所以可以用函数名作为参数!
如:
function add(num1, num2){
return (num1+num2);
}
function res(num1,num2,add){
return add(num1,num2);
}
alert(res(1,2,add));
2.用匿名函数来调用:
function add(num1, num2, func){
return func(num1,num2);
}
alert(add(1,2,function(num1,num2){
return (num1+num2);
}));
3.定义的同时执行
(function add(num1,num2,func){
return func(num1,num2);
})(100, 200,function(num1,num2){
alert(num1+num2);
});
其中函数名 add 可有可无!
eval("字符串"),会把字符串当作 js 脚本来执行,前提是字符串要符合JS 语法,里面的变量作用域只在其字符串内起作用!
如果用 window.eval("字符串"),则字符串中的变量在火狐浏览器是全局的,而在IE是局部的,如果用 window.execScript,则在IE下作用和在火狐下用 window.eval() 作用一样,火狐对 execScript不起作用,会报错!
数组声明:
1。用对象方式:
var a = new Array();如果 var a = new Array(数值); 则数值表示为 数组 a 的长度!
A。直接赋值:
var a = new Array(元素1,元素2,...);
B. 先声明,后赋值
var a = new Array();
a[0] = 元素1;
a[1] = 元素2;
.....
2. 隐匿声明:
var a = [];
A。直接赋值:
var a = [元素1,元素2,...];
声明后赋值:
var a = [];
a[0] = "元素1";
a[1] = "元素2";