D 03_JavaScript自定义方法和自定义对象
来源:互联网 发布:天戏网络 编辑:程序博客网 时间:2024/06/06 02:32
JavaScript自定义方法和自定义对象
自定义函数/自定义方法
2.7.1、函数简述及作用
如果一段代码需要被重复编写使用,那么我们为了方便统一编写使用,可以将其封装进一个函数(方法)中。
作用:增强代码的复用性
2.7.2、函数格式
<!DOCTYPE html><html><head><meta charset="UTF-8"><title></title><script type="text/javascript">/* * 自定义函数的用法 * js函数定义必须小写 * 参数定义无需定义返回类型,直接在function后面写方法名 * 参数定义无需var,一定不要用var否则报错 * JavaScript函数体中,return可以不写,也可以return 具体值,或者仅仅写return; * * js中最后定义的方法会把前面的同名方法覆盖 * js中仅用方法名来调用函数,即便形参不匹配,也不影响正常使用 * */function getSum(a,b,c){alert(a+"-"+b+"-"+c)}function getSum(a,b){alert(a+"-"+b)}//getSum(1,2);//第二种方式函数定义的匿名函数var sum=function (a,c){return a+c;}var result=sum(20,23);alert(result);//函数定义第三种var ccc=new Function("a","b","return a+b");</script></head><body></body></html>
l JavaScript函数定义必须用小写的function;
l JavaScript函数无需定义返回值类型,直接在function后面书写 方法名;
l 参数的定义无需使用var关键字,否则报错;
l JavaScript函数体中,return可以不写,也可以return 具体值,或者仅仅写return;
2.7.3、函数使用的注意事项
JavaScript函数调用执行完毕一定有返回值,值及类型根据return决定,如果未return具体值,返回值为undefined;
JavaScript函数若同名,则不存在方法重载,只有方法相互覆盖,最后定义的函数覆盖之前的定义;
因为JavaScript不存在函数重载,所以JavaScript仅根据方法名来调用函数,即使实参与函数的形参不匹配,也不会影响正常调用;
如果形参未赋值,就使用默认值undefined
2.8、自定义对象
2.8.1、function构造函数
我们知道,JavaScript中的引用数据类型都是对象,而对象在JavaScript中可以用函数来表示。
相当于java中创建某个class类
无形参格式:
function 对象名(){
函数体
}
l 带参数格式:
function 对象名(参数列表){
函数体
}
l 有属性格式:
function 对象名(){
this.属性名1=属性值1;
this.属性名2=属性值2;
…….
}
this表示当前对象。
示例1:(this表示的是Person对象)
<!DOCTYPE html><html><head><meta charset="UTF-8"><title></title><script>function Student(){this.name="小王";this.age="12";}var s=new Student();alert(s.age);alert(s.name);function Student(n,a){this.name=n;this.age=a;//在对象中定义一个方法this.getSum=function(a,b){return a+b;}}var s=new Student("老王","55");alert(s.age);alert(s.name);alert(s.getSum(2,3));</script></head><body></body></html>
应用场景:适用于对象构建及代码复用。
2.8.2、对象直接量
开发中可以用一种简单的方式直接创建自定义的JavaScript对象,这种方式称为“对象直接量”。
格式:
var 对象名 = {属性名1:”属性值1”,属性名2:”属性值2”,属性名3:”属性值3”……};
注:该方式直接创建出实例对象,无需构建函数,无需再new创建实例对象,直接使用即可
应用场景:适用于快速创建实例对象及数据封装。
<!DOCTYPE html><html><head><meta charset="UTF-8"><title></title><script type="text/javascript">/* * 在直接量中定义方法 * 格式 方法名:function(a,b){} */var Student={age:"21",name:"大炮",sex:"男",addSum:function(a,b){return a+b;}};alert(Student.age+" "+Student.name+" "+Student.sex)alert(Student.addSum(12,13));var person={name:"小炮",age:"23",sex:"小男人",getSum:function(a,b){return a+b}};alert(person.name+" "+person.sex+" "+person.getSum(111,111));</script></head><body></body></html>
- D 03_JavaScript自定义方法和自定义对象
- D 03_JavaScript中的BOM对象
- D 03_JavaScript引入方式和注解
- js自定义对象和方法
- js自定义对象和方法
- js自定义对象和方法
- js自定义对象和方法
- D 03_JavaScript概述
- D 03_JavaScript中的运算符和正则
- D 03_JavaScript中的变量
- s 点击a标签 获取a的自定义属性方法_javascript技巧
- 黑马程序员_javascript 函数和对象基础知识
- JScript String 对象自定义方法
- js自定义对象及其方法
- javascript 自定义对象,属性,方法
- 自定义对象支持print方法
- 给jquery对象添加自定义方法和扩展jquery类
- 给jquery对象添加自定义方法和扩展jquery类
- MPLS VPN 主站与子站通信
- VueJs第三天1 -动画与组件
- java 支付宝 接口开发
- Java实现-一行代码求两个数的最大公约数
- spring(四)AOP相关概念
- D 03_JavaScript自定义方法和自定义对象
- 彻底搞懂Android文件存储---内部存储,外部存储以及各种存储路径解惑
- 输入流输出流问题
- 手把手教你使用IDEA开发工具创建一个Maven项目
- 面试题25:二叉树中和为某一值的路径
- 输入两个日期得出相差的月份
- 主题四 指针和数组(下)----28.函数与指针分析
- 解决端口占用问题
- 我的网络编程学习之路——基本的TCP套接字API