javascript 基础4

一、构造函数

构造函数

一般使用大写字母开头,以便把本身和其余普通函数区别开。在 构造函数 中, this 指向被此 构造函数 建立出来的 对象javascript

var Car = function() {
  this.wheels = 4;
  this.engines = 1;
  this.seats = 1;
};

使用构造函数时,咱们经过在它前面使用 new 关键字 来对它进行调用。要使用 new 关键字 去调用构造函数。由于只有这样,Javascript才知道这是要去构造一个新 对象 ,而且把构造函数中的 this 指向这个新对象。向 构造函数 中添加 参数能够在调用 构造函数 时传入一组 参数。java

var Car = function(wheels,seats,engines) {
  //Change this constructor
  this.wheels = wheels;
  this.seats = seats;
  this.engines = engines;
};

//Try it out here
var myCar =  new Car(6,3,1);

私有属性

构造函数 中,使用咱们熟悉的 var 关键字去建立变量,来替代咱们使用 this 建立 属性数组

var Bike = function() {

  // 只能在这一行下面写代码
  var gear = 5;        //私有属性gear,下面定义两个公用方法对gear进行访问
  this.getGear = function(){
    return gear;
  };
  this.setGear = function(value){
    gear = value;
  };
  
};

二、数组迭代方法

map 方法会迭代数组中的每个元素,并根据回调函数来处理每个元素,最后返回一个新数组。注意,这个方法不会改变原始数组。函数

var oldArray = [1,2,3,4,5];
//新数组在原始数组基础上每一个元素加3
var newArray = oldArray.map(function(val){
  return val+3;
});

reduce 方法用来迭代一个数组,而且把它累积到一个值中。使用 reduce 方法时,你要传入一个回调函数。reduce 方法有一个可选的第二参数,它能够被用来设置累加器的初始值。若是没有在这定义初始值,那么初始值将变成数组中的第一项,而 currentVal 将从数组的第二项开始。this

var array = [4,5,6,7,8];
var singleVal = 0;
//求数组之和
singleVal = array.reduce(function(previousval,currentval){
  return previousval+currentval;
});

filter 方法用来迭代一个数组,而且按给出的条件过滤出符合的元素。filter 方法传入一个回调函数,这个回调函数会携带一个参数,参数为当前迭代的项(咱们叫它 val )。回调函数返回 true 的项会保留在数组中,返回 false 的项会被过滤出数组。spa

var oldArray = [1,2,3,4,5,6,7,8,9,10];
//获取原始数组中小于6的元素
var newArray = oldArray.filter(function(val){
  return val < 6;
});

三、排序方法

使用 sort 方法,你能够很容易的按字母顺序或数字顺序对数组中的元素进行排序。与咱们以前用的数组方法仅仅返回一个新数组不一样, sort 方法将改变原数组,返回被排序后的数组。sort 能够把比较函数做为参数传入。比较函数有返回值,当 a 小于 b,返回一个负数;当 a 大于 b,返回一个正数;相等时返回0。若是没有传入比较函数,它将把值所有转成字符串,并按照字母顺序进行排序。code

var array = [1, 12, 21, 2];
array.sort(function(a, b) {
  return a - b; //升序排列
});
array.sort(function(a, b) {
  return b - a; //降序排列
});

四、翻转数组

你可使用 reverse 方法来翻转数组。对象

var myArray = [1, 2, 3];
myArray.reverse();

五、合并数组

concat 方法能够用来把两个数组的内容合并到一个数组中。concat 方法的参数应该是一个数组。参数中的数组会拼接在原数组的后面,并做为一个新数组返回。排序

var oldArray = [1,2,3];
var newArray = [];
var concatMe = [4,5,6];
newArray = oldArray.concat(concatMe);

六、分割和链接字符串

var string = "Split me into an array";
var array = [];
// 分割字符串,返回数组
array = string.split(" ");

var joinMe = ["Split","me","into","an","array"];
var joinedString = ' ';
//链接符链接数组元素造成字符串
joinedString = joinMe.join(joinedString);
相关文章
相关标签/搜索