文档章节

javascript 基础4

ricardohn
 ricardohn
发布于 2016/11/29 09:35
字数 957
阅读 22
收藏 0

1、构造函数

构造函数

通常使用大写字母开头,以便把自己和其他普通函数区别开。在 构造函数 中, this 指向被此 构造函数 创建出来的 对象

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

使用构造函数时,我们通过在它前面使用 new 关键字 来对它进行调用。要使用 new 关键字 去调用构造函数。因为只有这样,Javascript才知道这是要去构造一个新 对象 ,并且把构造函数中的 this 指向这个新对象。向 构造函数 中添加 参数可以在调用 构造函数 时传入一组 参数。

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;
  };
  
};

2、数组迭代方法

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

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

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

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

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

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

3、排序方法

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

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

4、翻转数组

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

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

5、合并数组

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

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

6、分割和连接字符串

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);

 

© 著作权归作者所有

共有 人打赏支持
ricardohn
粉丝 1
博文 76
码字总数 30236
作品 0
成都
私信 提问
分享51本关于JavaScript方面的学习书籍(免费下载)

分享51本关于JavaScript方面的学习书籍(免费下载) 1、JavaScript面向对象15分钟教程 2、原型、作用域、闭包的完整解释 3、Javascript面向对象特性实现(封装、继承、接口) 4、JavaScript面向...

邓剑彬
2012/12/02
1K
12
学习Javascript的8张思维导图

分别归类为:  javascript变量  javascript运算符  javascript数组  javascript流程语句  javascript字符串函数  javascript函数基础  javascript基础DOM操作  javascript正则表达式...

thinkyoung
2014/09/23
0
0
JavaScript 语言基础知识点总结(思维导图)

(1)javascript 数组 (2)函数基础 (3)运算符 (4)流程语句 (5)正则表达式 (6)字符串函数 (7)数据类型 (8)变量 (9)window 对象 (10)DOM基本操作 (11)一图知晓整个Javascr...

大数据之路
2012/11/26
0
2
5 个非常有用的 JavaScript 调试工具

JavaScript被称作以原型(prototype)为基础的语言。这种语言有很多特色,比如动态和弱类型,它还有一等函数(first class function)。另一个特点是它是一个多范型(multi-paradigm)语言,支持...

tsl0922
2012/05/06
4.8K
11
重庆公司招聘JS高手

工作地点:重庆 月薪5000-8000 JS程序员 1、精通Javascript,熟悉常见的JS开发框架(如prototype,jQuery、Mootools、YUI),能运用JS或框架开发程序; 2、能够脱离JS框架进行原生JS开发,能...

brucexc
2011/06/24
913
8

没有更多内容

加载失败,请刷新页面

加载更多

解析JQuery中each方法的使用

each() 方法规定为每个匹配元素规定运行的函数。写的十分的全面细致,具有一定的参考价值,对此有需要的朋友可以参考学习下。如有不足之处,欢迎批评指正。 概述: each() 方法规定为每个匹配...

前端攻城小牛
13分钟前
3
0
深入解析Vue开发动态刷新Echarts组件的教程

需求背景:dashboard作为目前企业中后台产品的“门面”,如何更加实时、高效、炫酷的对统计数据进行展示,是值得前端开发工程师和UI设计师共同思考的一个问题。今天就从0开始,封装一个动态渲...

peakedness丶
26分钟前
3
0
memcached

memcached 为了避免内存碎片化(传统的内存管理方式是,使用完通过malloc分配的内存后通过free来回收内存,这种方式容易产生内存碎片并降低操作系统对内存的管理效率),采用了 slab allocatio...

Cobbage
27分钟前
3
0
keepalived的介绍及配置高可用集群

12月19日任务 18.1 集群介绍 18.2 keepalived介绍 18.3/18.4/18.5 用keepalived配置高可用集群 集群介绍 根据功能划分为2类:高可用和负载均衡 高可用集群:通常为两台服务器,一台工作,另外...

robertt15
27分钟前
5
0
WiFi攻击的三种方式

导读 WiFi的安全问题已经引起了不少的使用者重视,甚至已经出现草木皆兵的现象。那么黑客到底是如何做到绕过身份验证来获取WiFi使用权的呢?主要有以下三种方式,其中最后一种方式十分简单。 ...

问题终结者
42分钟前
6
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部