- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
请不要使用 jQuery!
网络上说JS原生的String.concat()和join()函数要避免,因为它们的性能很差,一个简单的for() 循环的 += 赋值应该工作得更快。
所以我尝试用纯 JavaScript 创建一个函数来连接字符串。这在某种程度上是我的设想:
我想要一个主函数 concatenate(),它将连接所有传递的参数,并在每个连接的参数(最后一个参数除外)之后另外插入一个可变字符串。
<如果 main 函数是自己调用的,并且没有链式 .using() 函数,那么该变量字符串应该是一个空字符串,这意味着结果中没有分隔符。
我想要一个链式子函数 .using(),它将告诉主要的 concatenate() 函数除了默认的 '' 空之外的特定字符串在每个连接的段之后添加的字符串。
理论上,它应该是这样工作的:
concatenate('a','b','c'); /* result: 'abc' */
concatenate('a','b','c').using('-'); /* result: 'a-b-c' */
我想避免使用两个单独的函数,例如 concatenate() 和 concatenateUsing(),因为 concatenateUsing() 变体会这样必须使用一个特殊的常量参数(如 arguments[0] 或 arguments[arguments.length-1])作为注入(inject)的分隔符,这会非常不整洁。另外,我总是会忘记它是哪一个。
我还想避免使用两个单独的子方法取代 Concatenate 对象,例如 Concatenate.strings() 和 Concatenate.using() 或类似的。
这是我迄今为止失败的一些尝试......
尝试 #1:
function concatenate()
{
var result="";
if(this.separator===undefined){var separator=false;}
for(var i=0; i<arguments.length; i++)
{result += arguments[i] + ((separator && (i<arguments.length-1))?separator:'');}
this.using=function(x)
{
this.separator=x;
return this;
}
return result;
}
所以我想做的是:
检查 separator 变量是否未定义,这意味着它尚未从子方法中设置。
如果它未定义,则用值 false 声明它以供以后评估。
运行连接,如果 separator 的值不是 false 则在每个连接步骤中使用它 - 只要它不是最后一次迭代。
然后返回结果。
子方法 .using(x) 应该在某个地方设置分隔符 变量的值。
当然,这行不通。
尝试#2:
var concatenate = function()
{
var result="";
var separator="";
for(var i=0; i<arguments.length; i++)
{result += arguments[i] + ((separator && (i<arguments.length-1))?separator:'');}
return result;
}
concatenate.prototype.using=function(x)
{
this.separator=x;
return this;
}
它也不起作用,我假设当 this 从 using() 子方法返回时,var separator="" 的主要 concatenate() 函数只是再次用 ""覆盖值。
我现在尝试了 4 或 5 种不同的方式,但我不想让您对其他所有方式感到厌烦。
有人知道这个谜题的解法吗?非常感谢!
最佳答案
你想做的事是不可能的。
您不能将某些内容链接到返回原语的方法调用,因为原语没有(自定义)方法1。
而且你不能让第一个函数返回不同的东西,这取决于某些东西是否被链接,因为它不知道它的调用上下文并且必须在方法调用被评估之前返回结果。
最好的办法是返回一个可以使用自定义 toString
方法进行字符串化的对象,并且还提供 using
东西。这将是一些类似的东西
function concatenate() {
return {
args: Array.from(arguments), // ES6 for simplicity
using: function(separator) {
return this.args.join(separator);
},
toString: function() {
return this.args.join("");
}
};
}
console.log(String(concatenate('a','b','c'))); // result: 'abc'
// alternatively, use ""+… or explicitly call the ….toString() method
console.log(concatenate('a','b','c').using('-')); // result: 'a-b-c'
1:不,你不想知道workarounds .
关于JavaScript 链式连接函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30625449/
一晃五年没写博客了,依旧再C#上耕耘,依旧没有啥建树,现在也不知道.net上还有多少人再使用,在这里分享一些自己觉得写的还算优雅的代码。 对于自己写着完的代码,我特别喜欢链式(来源于jQuer
我正在构建一个吉他和弦查找应用程序。我使用多维数组来表示指板。数组中的每个元素都由具有字符串属性“Note”的 FretSpace 结构表示。为了初始化指板上的音符属性,我传递了要处理的吉他弦的详细信
我在演示代码中使用 setTimeout 函数模拟了 3 个 ajax 调用。我将从一段运行良好的代码开始:所有调用都是并行进行的,我希望所有调用都能成功,否则会出现错误。 var p1 = func
谁能解释一下? a = [2,3,4] b = [5,6,8,9] print(len(a) > 0) print(len(b) > 0) print((len(a) > 0) & len(b) >
我正在处理具有多个子 JSONObject 的 JSONObject。这是我填写内容的方式: myJson.getJSONObject(CAT_NAME).put(VAR_NAME, var)
想象一下这种情况,我有一个需要检查属性的对象。但是,该对象当前可以具有空值。 如何在一个“if”条件下检查这两个条件? 目前,我必须做这样的事情: if (myObject != null) {
我有一个对象集合,称它们为obj。他们有一个 act() 方法。 act() 方法最终会导致 o 上的 event() observable 调用 onComplete。 链接这些的好方法是什么? 即
假设我有一个列表变量 datalist 存储 10,000 个字符串实体。QTableView 只需要显示其中的一些实体。这就是为什么 QTableView 被指定为 QSortFilterProxy
我正在寻找支持链式 MSI 安装的工具(最好不是 InstallShield,而且最好是便宜/免费的)。我有几个小型安装需要能够单独部署,但也需要作为一个组部署,我不想维护多个安装程序。 看起来我需要
在这种情况下,我想迭代集合中除最后 2 个元素之外的所有元素。 假设我采用了一种奇怪的方式,例如 x.Reverse().Skip(2).Reverse()。 每个 LINQ 操作是否会有效地生成一个
对于javascript来说非常陌生,我有两个html数字选择,包括年份,我想将第二个选择与第一个选择链接起来,这样当我在第一个选择中选择年份时(而第二个选择没有选项)首先),第二个选择应包括从所选数
有人可以向我解释一下为什么以下两个链式函数: // returns zero if okay var resetCounter = function (model) { return new Prom
所以我有 2 个 promise 函数。当第一个函数出现错误时,我希望它显示错误消息。当完成或失败时,我希望他们执行一个finally catch all 函数,但由于某种原因它不起作用。我的代码如下
我有一个函数 const func = () => server.insertPatientSurveyQuestionToDataBase(Store.getPatientID(), SurveyN
(async function() { var a,b; function flush(){ return new Promise(res => {
这个问题已经有答案了: Promise chaining: Use result from previous promise in next then callback [duplicate] (1
这可能不是专业正则表达式理解的问题。唯一重要的是因为我正在运行多个链式替换命令,这些命令会影响文本文件中的某些相同文本。我还想象在替换之前,根据分隔符词(需要多次替换)的使用方式对 txt 文件进行分
我正在尝试构建一组类来定义 OSI 堆栈中协议(protocol)的分层属性...从抽象意义上讲,我只需要从父 python 类继承属性,但我需要能够调用整个类链一次...所以,我正在寻找这样的东西.
我正在努力兑现 promise ,到目前为止我偶然发现了这一点: new Promise((resolve, reject) => { setTimeout(() => { r
我试图理解 promise ,我需要链接它们并装饰来自不同端点的对象宽度数据。 例如: 我的 Node-express 应用程序中有这个 //controller.js export const ge
我是一名优秀的程序员,十分优秀!