表达式语句

greeting ="Hello"+name;//赋值语句
i*=3;
count++;
delete o.x; //删除
alert(greeting); //函数
window.close();
y=Math.cos(x);

复合语句和空语句

function(){
x=Math.PI;
console.log("x="+x);
}
//初始化一个数组
for(i=0;i<a.length;a[i++]=0);

1.if…else…; else if

2.switch

3.while,do/while,for(in)

4.break,continue,return

5.标签语句

6.throw

  <script>
var str="Hello";
function demo(){
try{
var e=document.getElementById("txt").value;
if(e==""){
throw "请输入:";
}
}catch (err){
alert(err);
}
}
demo();
</script>

7.try/ catch/ finally

   <script>
var str="Hello";
function demo(){
try{
alert(str);
}catch (err){
alert(err);
}
}
demo();
</script>

8.with

嵌套很深的时候用with简化代码

document.forms[0].name.value;
document.forms[0].address.value;
document.forms[0].email.value; //直接访问表单元素
with(document.forms[0]){
name.value="";
address.value="";
email.value="";
}

9.debugger

以调试模式运行

10.use strict

严格代码解析

对象

1.对象常见用法:创建、设置、查找、删除、检测、枚举

2.属性特性:可写(是否可以设置值)、可枚举(是否能通过for/in循环返回)、可配置(是否可以删除或修改)

3.对象特性:原型、类、扩展标记

4.分类

(1)内置对象:ECMAScript规范定义的对象或类。如:字符串、数值、数组、函数、日期、正则表达式

(2)宿主对象:JavaScript的解释器所嵌入的宿主环境定义的(如Web浏览器)。如:表示网页结构的HTMLElement

(3)自定义对象:运行中的Javascript代码创建的对象

(4)自有属性:直接在对象中定义的属性

(5)继承属性:在对象的原型对象中定义的属性

创建对象

1.对象直接量

var empty={};       //没有任何属性
var point={x:0,y:0}; //两个属性
var book={
"main title":"JavaScript", //属性名有空格,必须用字符串表示
'sub-title':"The Definitive Guide", //属性名有连字符,必须用字符串
"for":"all audiences", //保留字,必须用引号
author:{
firstname:"David",
surname:"Flanggan"
}
};

2.通过new创建对象

var a=new Array();
var r=new RegExp("js");

3.原型

普通对象都有原型

所有内置构造函数都具有一个继承自Object.prototype的原型

一系列原型对象就是原型链

new Date创建的Date对象的属性同时继承Date.prototype和Object.prototype

4.Object.create()(待补充)

var o1=Object({x:1,y:2});   //o1继承了属性x和y

5.通过函数创建对象

function people(name,age){
this.name=name;
this.age=age;
}
son=new people("Mike",18);
document.write("name:"+name+" age:"+age);

属性的查询和设置

//查询
var author=book.author;
var title=book["main title"]; //[]内必须是字符串 //设置
book.author="David";
book["main title"]="JavaScript";

继承

在原型链中一直查找,直到null为止

var o={};
o.x=1;//给o一个x属性
var p=inherit(o);
p.y=2;//p继承o,且给p一个y属性
var q=inherit(p);
q.z=3;
var s=q.toString();
q.x+q.y //返回3,x和y分别继承自o和p

首先要检查原型链,判定是否允许复制操作

//例如,继承对象含一个只读属性x
var unitcircle={r:1};
var c=inherit(unitcircle);
c.x=1;
c.y=2;
c.r=2;/*覆盖继承来的r属性*/
unitcircle.r; /*返回1,原型对象没有修改*/

属性访问错误

查询不存在的属性不会报错,返回undefined

查询不存在的对象(如null和undefined)的属性,会报错

设置属性失败:

1.继承只读属性

2.继承已继承且只读的属性

3.没有使用setter方法继承属性???

book.subtitle;//返回undefined,subtitle属性不存在
var length=book.subtitle.length;//抛出类型错误异常,undefined没有length属性
//避免出错的方法
var len=undefined;
if(book){
if(book.subtitle) len=book.subtitle.length;
}
/*或者*/
var len=book&&book.subtitle&&book.subtitle.length;

删除属性

delete只是断开属性和数组对象的联系,而不会去操作属性

delete book.author;//book不再有author属性
delete book["main title"];//book不再有main title属性

只能删除自有属性,不能删除继承属性

删除成功没有任何副作用,返回true

o={x:1}
delete o.x;//删除x,返回true

不能删除会返回false的情况

删除不可配置属性(例如,通过变量声明和函数声明创建的全局对象的属性),报错:类型错误

delete  Object.prototype;//不可配置,不能删除
var x=1;//声明一个全局变量
delete this.x;//返回false
var f(){};
delete this f;//返回false this.x=1;//声明一个可配置的全局属性
delete x;//返回true

第四章 javascript的语句、对象笔记摘要的更多相关文章

  1. 第四章 JavaScript操作DOM对象

    第四章   JavaScript操作DOM对象 一.DOM操作 DOM是Document Object Model的缩写,即文档对象模型,是基于文档编程的一套API接口,1988年,W3C发布了第一级 ...

  2. JavaScript进阶 - 第7章 JavaScript内置对象

    第7章 JavaScript内置对象 7-1 什么是对象 JavaScript 中的所有事物都是对象,如:字符串.数值.数组.函数等,每个对象带有属性和方法. 对象的属性:反映该对象某些特定的性质的, ...

  3. 第三章 JavaScript操作BOM对象

    第三章   JavaScript操作BOM对象 一.window对象 浏览器对象模型(BOM)是javascript的组成之一,它提供了独立与浏览器窗口进行交换的对象,使用浏览器对象模型可以实现与HT ...

  4. JQuery制作网页—— 第二章 JavaScript操作BOM对象

    1.window对象: 浏览器对象模型(BOM)是javascript的组成之一, 它提供了独立与浏览器窗口进行交换的对象,使用浏览器对象模型可以实现与HTML的交互. 它的作用是将相关的元素组织包装 ...

  5. 《Java从入门到失业》第四章:类和对象(4.5):包

    4.5包 前面我们已经听过包(package)这个概念了,比如String类在java.lang包下,Arrays类在java.util包下.那么为什么要引入包的概念呢?我们思考一个问题:java类库 ...

  6. 《Visual C# 从入门到精通》第三章使用判断语句——读书笔记

    第3章 使用判断语句 3.1 使用布尔操作符 布尔操作符是求值为true或false的操作符. C#提供了几个非常有用的布尔操作符,其中最简单的是NOT(求反)操作符,它用感叹号(!)表示.!操作符求 ...

  7. JQuery制作网页—— 第四章JavaScript对象及初识面向对象

    1.对象:在JavaScript中,所有事物都是对象,如字符串.数值.数组.函数等. JavaScript中的基本数据类型: number(数值类型)   string(字符串类型)  boolean ...

  8. Programming In Scala笔记-第四章、类和对象

    类似于Java,Scala中也有类和对象的概念. 一.类.属性和方法 1.类 类是对一类事物的抽象,当一个类被定义后,就可以以该定义为模板,定义该类的一系列对象.比如说有以下一个模板 人类: 有姓名: ...

  9. Java基础知识笔记第四章:类和对象

      编程语言的几个发展阶段 面向机器语言 面向过程语言 面向对象语言:封装.继承.多态 类 类声明 class Person{ ....... } class 植物{ ....... } 类体 类使用 ...

随机推荐

  1. Chrome 插件安装技巧

    参考http://blog.csdn.net/shiyaru1314/article/details/49303317 最近在学习WEBAPI  由于没有界面可以调试,需要安装Chrome中的插件 P ...

  2. day34进程相关

    进程1 什么是进程    进程指的是一个正在进行/运行的程序,进程是用来描述程序执行过程的虚拟概念    进程vs程序    程序:一堆代码    进程:程序的执行的过程    进程的概念起源于操作系 ...

  3. Laravel常见问题集锦

    1.提示:Syntax error or access violation: 1071 Specified key was too long; max key length is 767 bytes? ...

  4. json字符串装List<Object>

    List<SearchParam> ts = (List<SearchParam>) JSONArray.parseArray(jsonStr, SearchParam.cla ...

  5. 移动端UL列表无法平滑向下滚动问题

    问题说明: 移动端向上滑动后,,列表无法自动滚动到底部~~而是类似屏幕"沾手"的效果(手离开屏幕直接停止在当前~列表不会自动向下滚动一段) 问题原因: 页面中存在如下代码: 当前页 ...

  6. Sqlite安装教程

    Sqlite下载页面:http://www.sqlite.org/download.html Windows安装 需要下载 sqlite-tools-win32-*.zip 和 sqlite-dll- ...

  7. zabbix 3.4 直接 发现端口并作存活监控(带服务名)

    客户端配置 1.脚本 [root@es1 home]# cat /home/port_service.sh #!/bin/bash#by Mr.lu#su rootportarray=(`sudo - ...

  8. 【读书笔记】深入应用C++11代码优化与工业级应用 读书笔记01

    第一章 使用C++11让程序更简洁.更现代 1.1  类型推导 1.1.1  auto类型推导 1.auto关键字的新意义 不同于python等动态类型语言的运行时进行变量类型的推导,隐式类型定义的类 ...

  9. project1

    知识漏洞  有空就默写一下-.- [概念] 要好好理解并且背下来记住 MVC要分开,Servlet里面不处理计算的逻辑,只有调用函数(是不是变量传进来以后,调用都不能有呢?) clear map不能直 ...

  10. [转贴]LTP--linux稳定性测试 linux性能测试 ltp压力测试 ---IBM 的 linux test project

    https://blog.csdn.net/melody157398/article/details/24354415   LTP--linux稳定性测试 linux性能测试 ltp压力测试 ---I ...