本文实例讲述了js中getter和setter用法。分享给大家供大家参考,具体如下:
在学习Vue计算属性时,有一句“计算属性默认只有 getter ,不过在需要时你也可以提供一个 setter”。
getter和setter到底是什么?于是我查找了资料:
在Es5中可以使用getter和setter部分改写默认操作,但是只能应用在单个属性上,无法应用在整个对象上。getter是一个隐藏函数,会在获取属性值时调用。setter也是一个隐藏属性,会在设置属性值时调用。
例子:
var my = {
get a(){
return 2
}
};
.defineProperty(
my , //目标对象
"b", //属性名
{ //描述符
//给b设置一个getter
get:function(){
return this.a*2
},
//确保b会出现在对象的属性列表中
enumerable:true
}
);
console.log(my .a) //2
console.log(my .b) //4
这里使用在线HTML/CSS/ 代码运行工具:http://tools.jb51.net/code/HtmlJsRun,测试结果如下:

不管是对象文字语法中的get a( ) { ...... },还是defineProperty(......)中的显式定义,二者都会在对象中创建一个不包含值的属性,对于这个属性的访问会自动调用一个隐藏函数,它的返回值会被当作属性访问的返回值。(也就是说my .a不用加执行括号,vue中计算属性默认有getter,调用计算属性不用在后面加"( )")
var obj = {
//给a定义一个getter
get a(){
return 2;
}
};
obj.a = 3;
console.log(obj.a); //2
使用在线HTML/CSS/ 代码运行工具:http://tools.jb51.net/code/HtmlJsRun,测试结果如下:

由于对a只定义了getter,所以对a的set操作会忽略赋值操作,不会抛错。而且即便有合法的setter,由于我们自定义的getter只会返回2,所以set操作是没有意义的。
更多关于 相关内容感兴趣的读者可查看本站专题:《 面向对象入门教程》、《 常用函数技巧汇总》、《 错误与调试技巧总结》、《 数据结构与算法技巧总结》、《 遍历算法与技巧总结》及《 数学运算用法总结》
希望本文所述对大家 程序设计有所帮助。
继续阅读与本文标签相同的文章
-
SpringCloud微服务(07):Zipkin组件,实现请求链路追踪
2026-05-17栏目: 教程
-
阿里云推出高性能一体机POLARDB BOX,全面兼容Oracle、mysql
2026-05-17栏目: 教程
-
利用java反射和java-parser制作可以迭代、分布式、全栈式代码生成器的研究
2026-05-17栏目: 教程
-
CI做到90%的行覆盖率,真能发现BUG吗?
2026-05-17栏目: 教程
-
深入浅出:Hadoop的start-balancer.sh与hdfs balancer分布式数据均衡
2026-05-17栏目: 教程
