js基础语法
    Netcape   
    js基础语法规范(ECMAScript1,2,3,3.1,5(IE9),6   ES    ES6=es2015) DOM BOM  
       BOM :是由浏览器厂商各自实现的,所以差异比较大
       DOM:相关的规范  是由W3C维护的
    Node的优势  没有浏览器的兼容性问题
    前端项目尽量不要使用ES6,需要考虑兼容性问题
--------------------------------数据类型---------------------------
1.数据类型分类:
            基本数据类型:number   string   boolean      undefined    null
            复杂数据类型:对象(数组,函数,日期)
 
undefined:数据未定义的一种状态
2.typeof 返回的数据类型
可以返回这六种数据类型:number  string  boolean  function  undefined  object
日期,数组,正则都是object类型
可以使用typeof来检测前5中的数据类型 '
注意返回的是字符串   小写
console.log(typeof  alert());//function  使用typeof检测函数 返回的是function
 
3.逻辑运算符
&&  :   左边为真的话,返回右边;左边为假的话,返回左边      (如果左边为真,需要计算右边所以会返回右边的结果)
||  :左边为真的话,返回左边;左边为假的话  返回右边   (如果左边为真,就不需要再计算右边了,所以会直接返回左边的值)
console.log(undefined  &&  10);//undefined
console.log(0 || 3);//3  
 
真假值:
假值:  空字符串""   数值0   false     null(声明的变量赋值了但是赋值的是空值)   undefined(变量声明了但是没有定义)    NaN(不是一个数字,NaN本身是number类型的)  
 
4.获取对象未定义的属性的话返回的是undefined不是  is not defined
var  obj = {name:''xiaoming"};
console.log(obj.age);//undefined
5.值类型  引用类型
值类型:数字 字符串  boolean  null  undefined
引用类型:对象
 
5.  instanceof
var  result = obj  instanceof   XXX;
返回值是一个boolean类型
检测obj是否是XXX类的一个实例
  1. var obj ={};
  2. console.log(obj instanceof Object);
  3. var arr =[1,2,3,4];
  4. console.log(arr instanceof Array);
    
constructor属性:保存了对构造特定对象实例的函数的引用
  1. console.log(arr.constructor==Array);//true
  2. console.log(obj.constructor==Object);//true
  3. console.log(num.constructor==Number);//true
 
代码调试   异常捕获
面向对象基础复习
构造函数和原型
 
变量声明提升(词法作用域 原理性的介绍)
作用域:全局作用域     局部作用域(写一个函数就产生了一个局部作用域)
 
 
  1. function bar(){
  2. function foo(){}
  3. foo =10;//2.给变量foo赋值 10 foo变为了一个number类型
  4. // function foo() {}//1.函数声明 提升到当前作用域的顶端
  5. return foo;//3.将number类型的的foo返回
  6. }
  7. // console.log(foo);
  8. console.log(typeof bar());
 
  1. function fun(a, b){
  2. for(var i =0; i < arguments.length; i++){
  3. console.log(arguments[i]);//分别打印的函数的参数
  4. }
  5. return a + b;
  6. }
  7. console.log(fun(3));//NaN 3+undefined 得到是一个NaN
  1. var foo =function bar(name){
  2. console.log("hello"+ name);
  3. };
  4. foo("world");
  5. //bar();//无法打印 bar is not defined
  6. /*在函数内部,bar可以被访问,此时的bar就相当于foo,相当于函数本身*/
  7. //只能通过打印foo.toString()从而找到bar
  8. console.log(foo()== bar());
  9. console.log(foo.toString());//打印的是function bar(name) 函数体
 

JS基础复习的更多相关文章

  1. JS基础 复习: Javascript的书写位置

    爱创课堂JS基础 复习: Javascript的书写位置复习 js书写位置:body标签的最底部.实际工作中使用书写在head标签内一对script标签里.alert()弹出框.console.log ...

  2. js基础复习点

    1.变量   var num=10;       var num1,num2,num3;   num1=10;   num2=20;   num3=30;       var num1=10,num2 ...

  3. js基础复习~Array对象

    Array对象 lenght 获取到数组的长度 concat() 方法用于合并两个或多个数组.此方法不会更改两大有数组,而是返回一个新的数组 let arr1 = ["a",&qu ...

  4. [JS复习] JS 基础知识

    项目结尾,空闲时间,又把<JS 基础知识> 这本书过了一遍,温故知新后,很多知其然不知其所以然的内容 豁然开朗. [1. 用于范围的标签] display  :inline or bloc ...

  5. day51 JS基础

    复习 1.字体图标 用i标签, 设置类名, 与第三方字体图标库进行图标匹配 <link rel="stylesheet" href="font-awesome-4. ...

  6. js 基础篇(点击事件轮播图的实现)

    轮播图在以后的应用中还是比较常见的,不需要多少行代码就能实现.但是在只掌握了js基础知识的情况下,怎么来用较少的而且逻辑又简单的方法来实现呢?下面来分析下几种不同的做法: 1.利用位移的方法来实现 首 ...

  7. 《CSS权威指南》基础复习+查漏补缺

    前几天被朋友问到几个CSS问题,讲道理么,接触CSS是从大一开始的,也算有3年半了,总是觉得自己对css算是熟悉的了.然而还是被几个问题弄的"一脸懵逼"... 然后又是刚入职新公司 ...

  8. js 基础

    js基础知识点总结 如何在一个网站或者一个页面,去书写你的js代码:1.js的分层(功能):jquery(tool) 组件(ui) 应用(app),mvc(backboneJs)2.js的规划():避 ...

  9. js基础练习二之简易日历

    今天学到了js基础教程3,昨天的课后练习还没来的及做,这个是类似简易日历的小案例,视频还没听完,今晚继续...... 先看效果图: 其实做过前面的Tab选项卡,这个就很好理解了,通过鼠标放在不同月份月 ...

随机推荐

  1. 01java基础笔记

    计算机组成:运算器,控制器,存储器,输入输出设备(外部设备I/O设备) 机器语言:机器语言,汇编语言,高级语言 人机交互:命令行方式,图形化界面交互方式 JAVA语言平台分为:J2SE,J2ME,J2 ...

  2. J. The Volcano Eruption(圆相交+并查集)

    题目链接:https://codeforces.com/gym/101915/problem/J 思路:将所有相交的圆用并查集维护看做一个整体,然后枚举每个整体的左边界和右边界,判断能不能同时覆盖整个 ...

  3. crypto 密码加密

    转自 'use strict'; var crypto = require('crypto'); /** * generates random string of characters i.e sal ...

  4. lucene简单使用

    lucene7以上最低要求jdk1.8 lucene下载地址: http://archive.apache.org/dist/lucene/java/ <dependency> <g ...

  5. Java finally块

    try块也可以有零个或一个finally块. finally块总是与try块一起使用. 语法 finally块的语法是: 1 2 3 finally  {     // Code for finall ...

  6. 第一记 搭建Java集成开发环境

    一.JDK JDK可以前往oracle官网进行下载并进行安装(我这边使用的是jdk1.8版本,也推荐使用jdk1.8及以上的) 下图是默认路径安装完成后的截图 安装完成会产生这两个文件夹 二.配置环境 ...

  7. python基础【第六篇】

    list列表 基本结构 lst =[1,2,3,5,6] 为什么学列表? 列表能够存储比字符串更多的数据 列表能够存储各种数据类型 列表的注意点 列表是有序的 列表是可变的,支持索引,切片,步 切片后 ...

  8. python-模块-包

    一 模块 1 什么是模块? 常见的场景:一个模块就是一个包含了python定义和声明的文件,文件名就是模块名字加上.py的后缀. 但其实import加载的模块分为四个通用类别: 1 使用python编 ...

  9. JS提示信息来检测相应id的标签

    2015-07~2015-08 (其中$为document.getElementById()) 使用span提示信息来检测相应id的标签,没有返回值 infoTips("LRYH" ...

  10. 《构建之法》IT行业的创新 读书笔记 WEEK 5

    本周选读邹欣老师的<构建之法>第16章——IT行业的创新. 邹欣老师将本章话题分成五个部分来阐述:创新的迷思.创新的时机.创新的招数.魔方的创新.创新和作坊,博主认为时机和招数这两个部分在 ...