一、JavaScript函数

1.定义函数:函数的通用语法如下

function function_name([parameter [, ...]])
{
statements;
}
  • 由关键字function开始函数的定义
  • 接着是函数名,它必须由字母或下划线开始,后面可以是一串字母、数字、$符号或下划线
  • 必须带有括号,括号里的参数是可选的,多个参数用逗号(,)隔开
  • 封闭的大括号中书写函数代码

2.参数数组(arguments):参数数组可以使得在处理多个参数的变量时更灵活。

function displayItems()
{
for(j = 0; j < displayItems.arguments.length; ++j)
document.write(displayItems.arguments[j] + "<br />")
}

3.函数返回值:使用return语句返回函数结果。

document.write(fixNames("the","DALLAS","CowBoys"))
function fixNames()
{
var s = ""
for (var i = 0; i < fixNames.arguments.length; ++i)
{
s += fixNames.arguments[i].charAt(0).toUpperCase() +
fixNames.arguments[i].substr(1).toLowerCase() + " " }
return s.substr(0,s.length-1)
}

上面的代码将输入的字符的首字变为大写,其余字母为小写,并将字符拼接后返回。

如果我们并不想将字符拼接起来,而是返回分离的单个字符,可以使函数返回一个数组:

words = fixNames("the","DALLAS","CowBoys")

for(j = 0; j < words.length; ++j)
document.write(words[j] + "<br />") function fixNames()
{
  var s = new Array()
  for(j = 0; j < fixNames.arguments.length; ++j)
  s[j] = fixNames.arguments[j].charAt(0).toUpperCase() +
  fixNames.arguments[j].substr(1).toLowerCase()
  return s
}

二、JavaScript对象

1.与其他面向对象的编程语言有一点不一样,JavaScript是基于原型的面向对象的语言,不是严格的面向对象的语言。JavaScript中没有传统意义上的类去实例化对象 ,但是为了理解方便,我们可以引入概念上的类。对象可以通过一个叫做构造函数的特殊函数来生成的,我们也可以把这个过程看成是类的声明。下面我们来看看一个具体实例:User类的构造方法。

function User(forename,username,password)
{
this.forename = forename
this.username = username
this.password = password this.showUser = function()
{
document.write("ForeName: " + this.forename + "<br />")
document.write("UserName: " + this.Username + "<br />")
document.write("Password: " + this.password + "<br />")
}
}

该函数与一般的函数有两点不同:

  1. 它引用一个名为this的对象,当程序通过运行这个函数创建一个User实例时,this引用被创建的实例。
  2. 在函数内创建一个名为showUser的新函数

我们可以把这个函数看成一个类:USer类

2.创建对象:使用new关键字创建对象

//直接使用new关键字创建对象
detail = new User("Wolfgang","w.a.mozart","composer") //或者创建空的对象,然后再赋值
detail = new User()
detail.forename = "Wolfgang"
detail.username = "w.a.mozart"
detail.password = "composer" //此外,可以为创建好的对象添加新的属性
detail.greeting = "Hello"

3.访问对象:JavaScript也使用句号(.)来访问一个对象的属性和方法,

4.prototype(原型)关键字:使用prototype定义的属性和方法,类似C++中的静态属性和静态方法。所有由这个类实例化的对象共享这个prototype属性或方法,而不会为每个对象都创建一个单独的。可以说,prototype的属性和方法是类所拥有的,类实例化出来的对象拥有的不过是它的一个引用。

function User(forename,username,password)
{
this.forename = forename
this.username = username
this.password = password User.prototype.showUser = function()
{
document.write("ForeName: " + this.forename + "<br />")
document.write("UserName: " + this.Username + "<br />")
document.write("Password: " + this.password + "<br />")
}
}

三、JavaScript数组

1.数组的创建:可以使用new关键字也可以使用缩略形式声明数组,然后使用push方法往数组中添加新的元素;也可以声明有初始化值的数组。

//声明一个空的数组
myarray = new Array()
//或者用缩略形式:myarray = [] //使用push方法往数组中添加新的元素
myarray.push("One")
myarray.push("Two")
myarray.push("Three") //创建由初始化元素的数组
myarray2 = Array("One","Two","Three") //使用length方法获取数组的长度
document.write(myarray.length)

2.关联数组:JavaScript的关联数组和python的字典很像。在JavaScript中创建关联数组需要在一对大括号"{  }"中定义一组元素"key:value",冒号左边的是索引,右边是数组元素对应索引的值。

myarray = {"One":"1",
"Two":"2",
"Three":"3"} for(key in myarray)
document.write(key + " = " +myarray[key] + "<br />")

3.使用数组方法:由于数组的强大作用,JavaScript提供了许多现成的方法来操作数组。

(1).concat方法:可以将两个数组或一个数组中的一系列值连接起来,比如下面的代码会输出"Banana,Grape,Carrot":

fruit = ['Banana','Grape']
document.write(fruit.concat("Carrot"))

(2).forEach方法:用于遍历数组,对数组的每个元素进行操作,使用语法如下

myarray.forEach(function(currentValue, index, arr), thisValue)

参数说明如下:

  • function(currentValue, index, arr):必须,数组中每个元素需要调用的函数。

    • currentValue:必须,当前元素
    • index:可选,当前元素的索引
    • arr:可选,当前元素所属的数组对象
  • thisValue:可选,传递给函数的值一般用 "this" 值。如果这个参数为空, "undefined" 会传递给 "this" 值
pets = ["Cat","Dog","Rabbit","Hamster"]
pets.forEach(dispaly) function dispaly(element,index,array)
{
document.write("Element at index " + index + "has the value is " + element + "<br />")
}

注意:IE浏览器并不支持forEach方法。

(3).join方法:将数组内所有值转化为字符串,并将它们组合成一个更大的字符串,你可以选择连接的字符,默认是逗号","

pets = ["Cat","Dog","Rabbit","Hamster"]
document.write(pets.join(' '))
//输出结果为:Cat Dog Rabbit Hamster

(4).push和pop方法:push方法用于向数组中添加新的元素,pop方法用于删除数组中最新插入到数组中的元素并将其返回。

(5).reverse方法:将一个数组中的元素颠倒顺序

pets = ["Cat","Dog","Rabbit","Hamster"]
pets.reverse()

更多数组对象的属性和方法,可以参看菜鸟教程的JavaScript手册:JavaScript Array 对象

JavaScript函数、对象和数组的更多相关文章

  1. javaScript(8)---对象和数组

    javaScript(8)---对象和数组 学习要点: 1.Object类型 2.Array类型 3.对象中的方法 什么是对象,其实就是一种类型,即引用类型.而对象的值就是引用类型的实例.在ECMAS ...

  2. JSON.stringify()方法是将一个javascript值(对象或者数组)转换成为一个JSON字符串;JSON.parse()解析JSON字符串,构造由字符串描述的javascript值或对象

    JSON.stringify()方法是将一个javascript值(对象或者数组)转换成为一个JSON字符串:JSON.parse()解析JSON字符串,构造由字符串描述的javascript值或对象

  3. javaScript遍历对象、数组总结(转载)

    javaScript遍历对象.数组总结  转载来源 https://www.cnblogs.com/chenyablog/p/6477866.html 在日常工作过程中,我们对于javaScript遍 ...

  4. JavaScript 遍历对象、数组总结

    在日常工作过程中,我们对于javaScript遍历对象.数组的操作是十分的频繁的,今天抽空把经常用到的方法小结一下,方便今后参考使用!   javaScript遍历对象总结     1.使用Objec ...

  5. javascript 函数对象

    http://hi.baidu.com/gdancer/blog/item/a59e2c12479b4e54f919b814.html jQuery的一些写法就是基于这篇文章的原理的..     函数 ...

  6. JavaScript 之 对象/JSON/数组

    对象 简单说,所谓对象,就是一种无序的数据集合,由若干个“键值对”(key-value)构成. var obj = { p: 'Hello World' }; 上面代码中,大括号就定义了一个对象,它被 ...

  7. javascript中对象和数组的异同点

    一.JS声明对象或数组 JS对象:{ } JS数组:[ ] 对象 var b={m:'123',n:'abc'};alert(b.m);alert(b.n); 一维数组 var a=[1,2,3];a ...

  8. JavaScript 函数对象(Function 对象)

    函数对象 当我们对函数使用 typeof 操作符会返回什么? function f() { console.log('hello') } console.dir(typeof f) // functi ...

  9. JavaScript判断对象和数组

    在调用后端接口时,由于后端接口的不规范统一,接口最外层在没有数据时返回的是空数组(其实更想要的是空json对象,接口返回的data数据应该统一返回json对象,便于扩展),而在有数据时返回的是json ...

  10. JavaScript笔记:对象及数组

    一.对象 在javascript中,对象是拥有属性和方法的一种基本数据类型 1.创建object 创建object实例有如下两种方式: 使用new操作符后跟object构造函数创建,如下代码: var ...

随机推荐

  1. Linux动态DMA映射

    1. 几种地址类型 虚拟地址 Linux内核使用的地址是虚拟地址,数据类型为void *.例如,kmalloc()和vmalloc()函数返回值就是虚拟地址. 物理地址 处理器真实地址总线上的地址,数 ...

  2. JS中0.1+0.2!=0.3

    在控制台输入0.1+0.2,会得出以下结果 即不等于0.3.下面我们说一下原因. 一.存储原理 1.在计算机中数字无论是定点数还是浮点数都是以多位二进制的方式进行存储的.2.在JS中数字采用的IEEE ...

  3. C# Excel导出超出65536行报错 Invalid row number (65536) outside allowable range (0..65535)

    C# Excel导出超出65536行报错 Invalid row number (65536) outside allowable range (0..65535) 一:报错 Invalid row ...

  4. Java连载87-酒店管理系统练习、哈希表、函数

    一.创建一个酒店的房间管理系统 需求:这个酒店有五层,并且1-2层是标准间,3-4层是双人间,5层是豪华间:我们需要实时的显现各个房间的使用状态,并且我们可以预定某一个房间. package com. ...

  5. import,export深入理解

    export 最正常: var firstName = 'Michael'; var lastName = 'Jackson'; var year = 1958; export { firstName ...

  6. vscode侧边栏字体大小修改

    1.找到安装路径下,workbench.desktop.main.css 文件 C:\z_my_install\Microsoft VS Code\resources\app\out\vs\workb ...

  7. Intel 8086 标志寄存器及JCC指令表

    汇编 JCC指令表 JCC指条件跳转指令,CC就是指条件码. JCC指令 中文含义 英文原意 检查符号位 典型C应用 JZ/JE 若为0则跳转:若相等则跳转 jump if zero;jump if ...

  8. Java-跳跃路线

    题目: 小明参加了学校的趣味运动会,其中的一个项目是:跳格子.地上画着一些格子,每个格子里写一个字,如下所示: 从我做起振我做起振兴做起振兴中起振兴中华 比赛时,先站在左上角的写着“从”字的格子里,可 ...

  9. 理财收益的计算 计算浮点数的n次方 1466

    题目描述 老傻非常喜欢购买理财产品,而且这款理财产品被推销人员吹得特别高,对于贪财的老傻来说正中下怀,于是在心里盘算着买了它,自己就是亿万富豪,现需要你编写一个程序,帮老傻计算其收益,老傻的投入是R( ...

  10. mui下拉上拉(明一)

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name ...