Sint(1,2).j(10) // 13
这样的函数怎么实现。
function Sint(a,b){
this.val= a + b
}
Sint.prototype.j= function(e){
return this.val + e
}
这样操作需要 new Sint(1,2) ,有什么办法可以实现直接 Sint(1,2).j(10) 输出结果吗?
Sint(1,2).j(10) // 13
这样的函数怎么实现。
function Sint(a,b){
this.val= a + b
}
Sint.prototype.j= function(e){
return this.val + e
}
这样操作需要 new Sint(1,2) ,有什么办法可以实现直接 Sint(1,2).j(10) 输出结果吗?
let f = {
name: 'dell',
sayHi: function () {
console.log(`hello, my name is ${this.name}`)
return this
},
sayBye: function () {
console.log(`byebye~~~~`)
return this
}
}
f.sayHi().sayBye()
可以参考这一篇:优雅的函数式编程
function Sint(a: number, b: number) {
return {
val: a + b,
j: function (e: number) {
return this.val + e;
}
}
}
console.log(Sint(1,2).j(10)); // 13
function Sint(a: number, b: number) : any {
return new Proxy({} as {}, {
get(target, prop) {
if (prop === 'j') {
return (e: number) => a + b + e;
}
return Reflect.get(target, prop);
}
})
}
console.log(Sint(1, 2).j(10)); // 13
持续链 那得加一个启动函数
function Sints(a: number, b: number) {
return {
_count : a + b,
j: function (e: number) {
this._count += e
return this;
},
exec: function () {
return this._count;
}
}
}
console.log(Sints(1,2).j(10).j(20).j(30).exec())
function Sint(a, b) {
if (!(this instanceof Sint)) return new Sint(a, b)
this._num = a + b
}
Object.defineProperties(Sint.prototype, {
value: {
get() {
return this._num
}
},
add: {
value(n) {
this._num += n
return this
}
}
})
console.log(Sint(1, 2).add(10).add(-1).value) // 12
console.log(new Sint(1, 2).add(-1).add(-2).value) // 0
8 回答6k 阅读✓ 已解决
9 回答9.4k 阅读
6 回答5k 阅读✓ 已解决
5 回答3.6k 阅读✓ 已解决
4 回答8k 阅读✓ 已解决
7 回答10k 阅读
5 回答7.3k 阅读✓ 已解决
补充一个思路,直接打印没法做到直接输出值,但是可以利用参与计算时,底层会调用
Symbol.toPrimitive
所绑定的方法,是可以做到直接跟运算符号的使用示例