前言:

    因为工作需要,所以开始主攻前台JS方面的技术。在以前的工作中,使用过这门脚本语言。但是都是比较凌乱的,用到什么学什么,只是为了实现业务,而去使用。

    不会考虑到代码优化,封装对象等。今次特意借了这本《javascript 高级程序设计》 ,在每个晚上抽出一个小时来看这本纸质书,系统的学习这门语言。

    本文中摘录的都是一些在阅读中,感觉比较重要的信息。如果文中出现差错,欢迎园友拍砖。 


摘录:    

数据类型

 
undefined  使用var声明 但未对其初始化
 
Null null值  
 
Boolean  布尔型
 
Number 整数 浮点  parseInt("10",2)  parseFloat
 
String  字符串   toString()
 
Object 对象 :
 
构造函数  new Object()   
 
hasOwnProperty(propertyName) 实例中是否有给定的属性
 
isPrototypeof(object) 传入对象是否是另一个对象的原型
 
propertyIsEnumerable 
 
toString()
 
valueof()
 
/////////////////////////////////////////////////////////////
 
typeof() 函数结果(undefined boolean  string  number object function)
 
 
 
操作符
 
for-in:精确迭代语句,枚举对象属性
 
for(var propName in object){
 
     alert(propName):
}
 
 
函数
 
参数名:非必须 有内置参数数组 arguments
 
function say(){
 
     alert(argumenyt[0+" "+argument[1]);
}
 
say("jon","22");
 
变量 作用域和内存

 
基本类型:保存在栈内存的简单数据段,该值被完全保存在内存中       typeof()
 
引用类型:堆内存中的对象,变量中保存的只是指针 指向该内存中的值   object instanceof array   
 
 
垃圾回收机制
 
标记清除
 
引用计数
 
 
引用类型
 
var person = new Object()
person.name = "lili";
person.age="12";
 
var person = {name:"lili",agr:12 };
 
array类型

 
var color = new Array(3); //创建出长度为3 的数组
 
var color = new Array("red","yellow","blue");
 
var color = ["red","yellow","blue"];
 
数组下的toString()  toLocaleString()  该两个方法默认会调用数组下每项的toString()方法
 
若toLocaleString()被重写,则调用重写后的toLocaleString()
 
 
数组下的push() 及pop()方法。
 
push() 将项推入数组中,并返回数组的count
 
pop() 取到数组的最后一项  count值被减少
 
 
 
数组重排序reserse() sort()
 
reserse()  将数组进行反转
 
sort() 调用每项的toString()方法  然后按照升序排列数组
 
 
 
concat()  将数组进行合并
 

引用类型:函数内部属性

 
函数内部有两个特殊对象 arguments 和 this 
 
arguments 包含了函数中所有的传入参数,该对象包含了callee属性,指向拥有arguments的函数
 
例如例子 
function as(num){
 
     if(num>1){
 
          as(num -1);
     }else{
 
          break;
     }
          
}
可消除函数体与函数名的耦合度
 
function as(num){
 
     if(num>1){
 
          arguments.callee(num -1);
     }else{
 
          break;
     }
          
}
 
this 引用的是函数据以执行操作的对象 或者说函数在执行时的作用域
 
window.color = "red";
 
var o = {color:"blue"};
 
function sayColor(){
 
     alert(this.color);
}
 
sayColor();  red
 
o.sayColor = sayColor;
 
o.sayColor();  blue
 
 
函数属性和方法
 
ECMAscript 中的函数也是对象  因此函数也有属性和方法
 
每个函数包含了两个属性 
 
length:函数希望接受的命名参数的个数
 
prototype:
 
函数自带两个方法,可在特定作用域中调用函数

apply() :需要传入两个参数; 一个是函数运行的作用域。 另一个是传入参数的数组(or array or arguments对象)

call(); 一个是函数运行的作用域  而后剩下的参数是必须一一列举

此二者方法可以相同效果 可以根据实际参数来选择调用

而通过该函数的调用 可以扩充函数运行的作用域.实际上函数改变了this的值

window.color = "red";
   
    var o = {color :"blue"};
   
    function sayColor(){
   
           alert(this.color);
    }
   
   
    sayColor();   //red
   
    sayColor.call(this); //red  
   
    sayColor.call(window); //red
   
    sayColor.call(o); //blue

 
 
     内置对象

global对象 作为ECMAScript的终极对象,从任何角度看 都不存在。但是不属于任何其他对象的属性和方法  最终都是它的属性和方法
   
    isNaN()  isFinite()  parseInt()  parseFloat()
   
    1. 编码方法  
   
         encodeURI()   不会对本身属于URI的特殊字符进行编码

 
         encodeURIComponent() 会将对应编码替换所有非字母数字字符

 
     2.eval() 执行ECMAScript字符串
 
     eval("alert('hi')");  等价于 alert('hi')
 
     当解析器发现调用eval() 方法时 会将传入的参数 当成ECMAScript来解析 然后将执行结果插入到原位置
 
     通过eval()执行的代码被认为是包含该次调用的执行环境的一部分,因为有执行环境相同的作用域。
 
 

 
 

阅读摘录《javascript 高级程序设计》01的更多相关文章

  1. <JavaScript>如何阅读《JavaScript高级程序设计》(一)

    题外话 最近在看<JavaScript高级程序设计>这本书,面对着700多页的厚书籍,心里有点压力,所以我决定梳理一下..探究一下到底怎么读这本书.本书的内容好像只有到ES5...所以只能 ...

  2. 如何阅读《JavaScript高级程序设计》(一)

    题外话 最近在看<JavaScript高级程序设计>这本书,面对着700多页的厚书籍,心里有点压力,所以我决定梳理一下..探究一下到底怎么读这本书.本书的内容好像只有到ES5...所以只能 ...

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

    这个系列,我会把阅读<Javascript高级程序设计>之后,感觉讲的比较深入,而且实际使用价值较大的内容记录下来,并且注释上我的一些想法.做这个一方面是提升了我的阅读效果以及方便我以后阅 ...

  4. 《Javascript高级程序设计》阅读记录(一):第二、三章

    <Javascript高级程序设计>阅读记录(一) 这个系列,我会把阅读<Javascript高级程序设计>之后,感觉讲的比较深入,而且实际使用价值较大的内容记录下来,并且注释 ...

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

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

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

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

  7. 《Javascript高级程序设计》阅读记录(二):第四章

    这个系列之前文字地址:http://www.cnblogs.com/qixinbo/p/6984374.html 这个系列,我会把阅读<Javascript高级程序设计>之后,感觉讲的比较 ...

  8. 《JavaScript高级程序设计》读书笔记--前言

    起因 web编程过程使用javascript时感觉很吃力,效率很低.根本原因在于对javascript整个知识体系不熟,看来需要找些书脑补一下,同时欢迎众网友监督. 大神推荐书籍 看了博客大神们推荐的 ...

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

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

随机推荐

  1. Spark学习(二) -- Spark整体框架

    标签(空格分隔): Spark 还记得上次的wordCount程序嘛?通过这个小程序,我们来一窥Spark的框架是什么样子的. sc.textFile("/usr/local/Cellar/ ...

  2. ASP.NET中cookie与Fiter实现简单登陆,AllowAnonymous匿名登陆

    向服务器发送cookie 在登陆的时候,我们可以可以通过下列代码,向服务器发送cookie,其中包括自己的账号信息(不涉及加密),用以后面判断访问者. HttpCookie cookie = new ...

  3. 未解决的问题,登录163邮箱http://mail.163.com/,用xpath的方式定位密码输入框的时候,总是报找不到该元素

    退出的时候出现: xpath定位方法: 注意xpath路径写的太长,如果层级全部写完定位不到,就尝试去掉一些层级

  4. Docker镜像文件存储结构

    docker相关文件存放在:/var/lib/docker目录下 镜像的存储结构主要分两部分,一是镜像ID之间的关联,一是镜像ID与镜像名称之间的关联,前者的结构体叫Graph,后者叫TagStore ...

  5. jmeter+ant+jenkins+mac报告优化

    一.在上篇博客中生成的报告有两个问题: 1.date not defined 2.Min Time和Max Time显示成了NaN 二.Jmeter+Ant报告生成原理: 在解决问题之前,让我们先弄清 ...

  6. php : 基础(2)

    常量 常量是相对于变量来说的:是一个其中存储的数据不会也不应该改变的"标识符". 常量的使用,就2个方面:定义,取值. 常量的定义 //常量定义语法1: //define(&quo ...

  7. localhost访问错误Forbidden You don't have permission to access / on this server.解决办法(亲测)

    在httpd.conf文件下找到这段: <Directory /> Options FollowSymLinks AllowOverride None Order deny,allow D ...

  8. Android开源测试框架学习

    近期因工作需要,分析了一些Android的测试框架,在这也分享下整理完的资料. Android测试大致分三大块: 代码层测试 用户操作模拟,功能测试 安装部署及稳定性测试 代码层测试 对于一般java ...

  9. HTML5 中的Nav元素详解

    什么是Nav元素 Nav元素可以用作页面导航的链接组,在导航链接组里面有很多的链接,点击每个链接可以链接到其他页面或者当前页面的其他部分,并不是所有的链接组都要被放在nav元素里面,我们只需要把最主要 ...

  10. hibernate注解随笔—10月8日

    hibernate注解(herbinate4 jar包注解可用,使用hibernate3.3注解失败) 如果javabean与数据库中表名一致(不区分大小写),则注解不用写@Table(name=&q ...