我有两种方法可以用作可链式方法.可以链接其他方法以进一步修改文本.
left从左侧返回X个字符. right从右边返回X个字符.
目前我可以这样做:
var txt = "hello";
S$(txt).left(4).right(2).val //returns "ll"
我想做的就是这个.基本上我想在最后一个链式方法之后返回结果,而不必调用属性.这可能吗?
var txt = "hello";
S$(txt).left(4).right(2) //returns "ll"
以下是主要代码:
(function (global) {
var jInit = function(text){
this.text = text;
this.val = text;
}
var jIn = function(text){
return new jInit(text);
}
var jStringy = jStringy || jIn;
jInit.prototype.left = function (num_char) {
if (num_char == undefined) {
throw "Number of characters is required!";
}
this.val = this.val.substring(0, num_char);
return this;
}
jInit.prototype.right = function (numchar) {
this.val = this.val.substring(this.val.length - numchar, this.val.length);
return this;
}
global.jStringy = global.S$ = jStringy;
return this;
}(window));
你可以覆盖 valueOf
和toString
方法Object
来实现它.
例:
var myObject = { value: 5, valueOf: function(){ return this.value; }, toString: function() { return 'value of this object is' + this.value; } };
由于Javascript是一种鸭子打字语言,因此在表达式评估过程中无论它们来自哪里,都不会阻止您对原始值/对象执行数学运算和字符串连接.
例子:
console.log(myObject + 10);
将打印15
alert(myObject);
将打印'此对象的值为5'