美文网首页
JS 知识点

JS 知识点

作者: 大水啊大水 | 来源:发表于2017-04-11 10:40 被阅读7次

盒子模型

对于非替换的行内元素来说,尽管内容周围存在内边距与边框,但其占用空间(行高)由 line-height
属性决定

box-sizing 属性用于更改用于计算元素宽度和高度的默认的 CSS 盒子模型。可以使用此属性来模拟不正确支持CSS盒子模型规范的浏览器的行为。
content-box:默认值,标准盒子模型。width = 内容的宽度,height = 内容的高度。
border-box:width = border + padding + 内容的 width,height = border + padding + 内容的 height。

es6新特性

ES6常用语法整合
Babel是一个广泛使用的转码器,可以将ES6代码转为ES5代码,从而在现有环境执行。这意味着,你可以现在就用ES6编写程序,而不用担心现有环境是否支持。
class

class Cons{
  constructor(name, age) {
    this.name = name
    this.age = age
  }

  getMes() {
    console.log(`hello ${this.name} !`);
  }
}
let mesge = new Cons('ashin', 3)
mesge.getMes()

class Ctrn extends Cons {
  constructor(name, anu) {
    super(name)
    this.anu = anu
  }

  ingo() {
    console.log(`${this.name} & ${this.anu}`);
  }
}

let ster = new Ctrn('ashin', 3)
ster.getMes()
ster.ingo()

箭头操作符

var arr = [1,2,3]
arr.forEach(x=>console.log(x))

解构赋值
数组中的值会自动被解析到对应接收该值的变量中

var [name,,age] = ['a', 'b', 3]
console.log(name + age);

默认参数
定义函数的时候指定参数的默认值

// es5
function fn(name) {
  var name = name || 'a'
  console.log(name);
}
fn()//a

// es6
function fn(name='b') {
  console.log(name);
}
fn()//b

多行字符串
使用反引号`来创建字符串

//ES5

var str = 'The 3.1 work extends XPath and'
  +'XQuery with map and array data structures'
  +'along with additional functions and operators'
  +'for manipulating them; a primary motivation'
  +'was to enhance JSON support.';

//ES6

var roadPoem = `The 3.1 work extends XPath and
  XQuery with map and array data structures
  along with additional functions and operators
  for manipulating them; a primary motivation
  was to enhance JSON support.`;

字符串模版
由美元符号加花括号包裹的变量${name}

var name = 'will';
console.log(`my name is ${name}`);

扩展运算符

// es5
function add() {
  var arr = Array.prototype.slice.call(arguments)
  console.log(arr.reduce((x,y)=>x+y));
}
add(1,2,3)

// es6
function add(...args) {
  console.log(args.reduce((x,y)=>x+y));
}
add(1,2,3)

块级作用域
let与const 关键字!可以把let看成var,它定义的变量被限定在了特定范围内。const则用来定义常量,即无法被更改值的变量。共同点都是块级作用域。

//let
for (let i=0;i<2;i++){
  console.log(i);//输出: 0,1
}
console.log(i);//输出:0?

//const
const name='a';
name='b';   //报错

模块

// b.js
function fn(){
    console.log('hello world');
}
export fn;  

// a.js
module { fn } from "./b";
fn();
// 然后在HTML引入a文件运行

for of
我们都知道for in循环用于遍历数组,类数组或对象,ES6中新引入的for of循环功能相似,不同的是每次循环它提供的不是序号而是值。

var a = ['a', 'b', 'c']
for(x in a) {
  console.log(x);
} // 0 1 2

for(x of a) {
  console.log(x);
} // a b c

javascript中的面向对象

构造函数继承

Cat.prototype = new Animal();
Cat.prototype.constructor = Cat;

非构造函数继承

function object(o) {
    function F() {}
    F.prototype = o;
    return new F();
  }

JavaScript 继承简单理解与实现
JavaScript 原型理解与创建对象应用

详解https是如何确保安全的?

事件捕获事件冒泡事件代理
JavaScript 详说事件机制之冒泡、捕获、传播、委托
javascript 有没有更高效的事件绑定写法?

Javascript的this用法

clone: Object.create(obj)
http://www.cnblogs.com/yugege/p/6526215.html

相关文章

  • js小知识点

    js小知识点 整理 js小知识点 (一):获取元素 1:document.getElementById('id名'...

  • 小知识点集汇一

    小知识点集汇一 小知识点 node接口模拟返回 js接口模拟数据 mockjs mocha js 测试框架--教程...

  • 前端知识温习

    js知识点 温习js css知识点 温习css jquery温习 自己实现一个jquery vue框架温习 温习v...

  • js的浅拷贝与深拷贝

    js的浅拷贝与深拷贝 涉及知识点: js中的数据类型(基本类型,引用类型) js中的存储数据的堆栈相关知识点; 下...

  • 2018-08-22

    今天简单了解了一下关于js对象的知识点。包括JS 数字 JS 字符串 JS 日期 JS 数组 JS 逻辑 JS 算...

  • js旋转木马特效

    目标知识点 : 学习js数组的增删方法:(pop()、push()、shift()、unshift()) 练习js...

  • 前端小知识点综合大全

    小知识点 node接口模拟返回 js接口模拟数据 mockjs mocha js 测试框架--教程 git 教程 ...

  • 18-进阶:Canvas 画板

    本节知识点 JS知识点 获取标签的方法之一(id):document.getElementById(id) 鼠标按...

  • 02 JS and CSS Clock

    02 JS and CSS Clock 效果 效果Github 知识点 transition transform ...

  • react学习(2)

    知识点 1:babel.js的作用:ES6=>ES5,jsx=>js2:小案例

网友评论

      本文标题:JS 知识点

      本文链接:https://www.haomeiwen.com/subject/wlsyattx.html