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";
javascript 笔记(1)的更多相关文章
- [Effective JavaScript 笔记] 第4条:原始类型优于封闭对象
js有5种原始值类型:布尔值.数字.字符串.null和undefined. 用typeof检测一下: typeof true; //"boolean" typeof 2; //&q ...
- [Effective JavaScript 笔记] 第5条:避免对混合类型使用==运算符
“1.0e0”=={valueOf:function(){return true;}} 是值是多少? 这两个完全不同的值使用==运算符是相等的.为什么呢?请看<[Effective JavaSc ...
- [Effective JavaScript 笔记]第3章:使用函数--个人总结
前言 这一章把平时会用到,但不会深究的知识点,分开细化地讲解了.里面很多内容在高3等基础内容里,也有很多讲到.但由于本身书籍的篇幅较大,很容易忽视对应的小知识点.这章里的许多小提示都很有帮助,特别是在 ...
- [Effective JavaScript 笔记]第27条:使用闭包而不是字符串来封装代码
函数是一种将代码作为数据结构存储的便利方式,代码之后可以被执行.这使得富有表现力的高阶函数抽象如map和forEach成为可能.它也是js异步I/O方法的核心.与此同时,也可以将代码表示为字符串的形式 ...
- [Effective JavaScript 笔记]第28条:不要信赖函数对象的toString方法
js函数有一个非凡的特性,即将其源代码重现为字符串的能力. (function(x){ return x+1 }).toString();//"function (x){ return x+ ...
- 从头开始学JavaScript 笔记(一)——基础中的基础
原文:从头开始学JavaScript 笔记(一)--基础中的基础 概要:javascript的组成. 各个组成部分的作用 . 一.javascript的组成 javascript ECMASc ...
- 【原】javascript笔记之Array方法forEach&map&filter&some&every&reduce&reduceRight
做前端有多年了,看过不少技术文章,学了新的技术,但更新迭代快的大前端,庞大的知识库,很多学过就忘记了,特别在项目紧急的条件下,哪怕心中隐隐约约有学过一个方法,但会下意识的使用旧的方法去解决,多年前ES ...
- JavaScript笔记目录
JavaScript笔记目录 一.JavaScript简介 二.在HTML中使用JavaScript ...持续更新中,敬请期待
- 蛋糕仙人的javascript笔记
蛋糕仙人的javascript笔记:https://www.w3cschool.cn/kesyi/kesyi-nqej24rv.html
- JavaScript笔记(第一章,第二章)
JavaScript笔记(第一章,第二章) 第一章: <meta http-equiv="Content-Type" content="text/html; cha ...
随机推荐
- Http协议简单解析及web请求过程
HTTP协议: HTTP是一个属于应用层的面向对象的协议,由于其简捷.快速的方式,适用于分布式超媒体信息系统. 基于HTTP协议的客户端/服务器请求响应机制的信息交换过程包含下面几个步骤: 1) ...
- UIImage的使用
UIImage是IOS中层级比较高的一个用来加载和绘制图像的一个类,更底层的类还有CGImage,以及IOS5.0以后新增加的CIImage.今天我们主要聊一聊UIImage的三个属性: imageO ...
- 软中断&tasklet&工作队列
软中断 软中断的分配时静态的(即在编译时定义),而tasklet的分配和初始化能够在执行时进行. 软中断(即便是同一种类型的软中断)能够并发地运行在多个CPU上. 因此,软中断是可重入函数并且必须明白 ...
- iOS开发多线程篇---atomic nonatomic区别
摘要 atomic和nonatomic区别用来决定编译器生成的getter和setter是否为原子操 作.atomic提供多线程安全,是描述该变量是否支持多线程的同步访问,如果选择了atomic 那么 ...
- linux 配置 Apache mysql php最新版
第一部分:安装mysql 官方下载 mysql5.6.19 64位的rpm格式文件 0.rpm 四个mysql5.6.19 卸载默认的mysql yum -y remove mysql-libs-* ...
- bootstrap系列整理
去年的九月份做第一版文档站时, 就开始尝试使用bootstrap ,由于当时对node 还一知半解,大部分精力放在nodejs上,bootstrap只是拿来就用,起步文档都没看: 当别人提到 Norm ...
- overflow: hidden用法,不仅仅是隐藏溢出
overflow:hidden是大家常用到的CSS样式,但是大多数人对这个样式的理解仅仅局限于隐藏溢出,而对于清除浮动这个含义不是很了解. <!DOCTYPE html> <html ...
- start mysqld on Mac server
#!/bin/sh # Source the common setup functions for startup scripts test -r /etc/rc.common || exit 1 . ...
- javascript源码阅读推荐
作者:马 岩(Furzoom) (http://www.cnblogs.com/furzoom/)版权声明:本文的版权归作者与博客园共同所有.转载时请在明显地方注明本文的详细链接,未经作者同意请不要删 ...
- KindEditor 修改多图片上传显示限制大小和张数
在使用KindEditor的时候用到多图片上传时,提示有最多上传20张图片,单张图片容量不超过1MB: 修改的文件的地方在:kindeditor\plugins\multiimage\multiima ...