首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

为什么模板字符串中的数组显示为普通字符串?

模板字符串是一种特殊的字符串语法,它允许我们在字符串中插入变量或表达式。在模板字符串中,如果数组被插入到字符串中,它会被转换为普通字符串。

这是因为模板字符串在处理数组时,会调用数组的toString()方法将其转换为字符串。toString()方法会将数组的所有元素转换为字符串,并用逗号分隔。因此,当我们在模板字符串中插入数组时,实际上是将数组转换为了一个逗号分隔的字符串。

举个例子,假设有一个数组[1, 2, 3],如果我们将它插入到模板字符串中,例如:

代码语言:txt
复制
const arr = [1, 2, 3];
const str = `数组:${arr}`;
console.log(str);

输出结果将会是:

代码语言:txt
复制
数组:1,2,3

在这个例子中,数组[1, 2, 3]被转换为了字符串"1,2,3"

对于模板字符串中的数组,如果我们希望保留数组的原始形式,可以使用数组的join()方法将其转换为字符串,并指定一个自定义的分隔符。例如:

代码语言:txt
复制
const arr = [1, 2, 3];
const str = `数组:${arr.join(' | ')}`;
console.log(str);

输出结果将会是:

代码语言:txt
复制
数组:1 | 2 | 3

在这个例子中,数组[1, 2, 3]被转换为了字符串"1 | 2 | 3",使用了自定义的分隔符" | "

总结起来,模板字符串中的数组显示为普通字符串是因为模板字符串会调用数组的toString()方法将其转换为逗号分隔的字符串。如果我们希望保留数组的原始形式,可以使用数组的join()方法将其转换为字符串,并指定一个自定义的分隔符。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

JavaScript 模板字符串

☕ 语法 `text` `lin1 lin2` `text ${expr}` tag `text ${expr}` 详解 JavaScript 模板字符串使用反引号来包裹字符串内容而不是单引号或双引号...`line1 line2` //等价于 'line1\n' + 'line2' 内嵌表达式 使用模板字符串最大优势在于不必再使用繁琐字符串连接操作来连接普通字符串与表达式,而是可以直接在字符串内部写表达式...let a = 10; let b = 20; // '10 + 20 = 30' console.log(`${a} + ${b} = ${a + b}`); 带标签模板字符串 更高级形式模板字符串是带标签模板字符串...标签使您可以用函数解析模板字符串。标签函数第一个参数包含一个字符串数组。其余参数与表达式相关。最后,你函数可以返回处理好字符串(或者它可以返回完全不同东西 , 如下个例子所述)。...原始字符串 在标签函数第一个参数,存在一个特殊属性 raw ,我们可以通过它来访问模板字符串原始字符串,而不经过特殊字符替换。

1.4K20
  • 教你如何在jssplit函数分割字符串数组

    在一些程序操作,都需要把一串长长字符串,按照某一个字符把其分割成数组,然后再给数组进行排列或是任意组合,亦或者单独输出某一部份。...当然在js也给我们提供好了函数,来把一串字符串进行分割成数组,已便于我们方便组合或输出。 javascriptsplit定义与语法 定义 split() 方法用于把一个字符串分割成字符串数组。...字符串或正则表达式,从该参数指定地方分割 stringObject howmany:可选。该参数可指定返回数组最大长度。如果设置了该参数,返回子串不会多于这个参数指定数组。...关于sqlit示例 利用javascriptsplit分割一个字符串 代码 var str = "2,2,3,5,6,6"; //这是一字符串 var strs = new Array(); /...给果会输出:2 2 3 5 6 6 利用JSsplit函数分割一段英文,单字母显示 代码 var str = "How ary you"; //这是一字符串 var strs = new Array

    4.9K21

    java字符连接字符串数组_Java连接字符串最佳方法

    参考链接: Java字符串拼接 java字符连接字符串数组   最近有人问我这个问题–在Java中使用+运算符连接字符串是否对性能不利?    ...这让我开始思考Java连接字符串不同方法,以及它们如何相互对抗。...StringBuilder存储在变量高速缓存(第13行),而不是仅留在堆栈上。 我不知道为什么会这样,但是JIT也许可以做到这一点,我们将不得不看看时机如何。    ...毫不奇怪,因为它不必每次调用创建StringBuilder / StringBuffer而付出性能损失。...下一个测试将创建一个100个字符串数组,每个字符串包含10个字符。 基准测试比较了将100个字符串连接在一起不同方法所花费时间。

    3.6K30

    数组字符串匹配

    数组字符串匹配 题目内容 给你一个字符串数组 words ,数组每个字符串都可以看作是一个单词。请你按 任意 顺序返回 words 是其他单词字符串所有单词。...如果你可以删除 words[j] 最左侧和/或最右侧若干字符得到 word[i] ,那么字符串 words[i] 就是 words[j] 一个子字符串。...示例 1: 输入:words = [“mass”,“as”,“hero”,“superhero”] 输出:[“as”,“hero”] 解释:“as” 是 “mass” 字符串,“hero” 是...“superhero” 字符串。...builder 第二个循环去对比字符串,如果字符串是子字符串那么一定会出现两次, 所以判断首次出现位置和第二次出现位置不同,就代表他是子字符串 解题代码如下: class Solution {

    2.2K40

    C++ 原始字符串文字及C++ 字符串数组(1-2)

    C++ 原始字符串文字 在 C++ ,为了转义像“\n”这样字符,我们使用一个额外“\”。从 C++ 11 开始,我们可以使用未处理转义字符(如 \n \t 或 \” )原始字符串。...原始字符串语法是文字以 R”( 开头,以 )” 结尾。 让我们看一个在 C++ 查看原始字符串文字示例: // C++ 程序来演示原始字符串工作。...\n C++ 字符串数组 在 C 和 C++ 字符串是一维字符数组,而 C 字符串数组是二维字符数组。声明它们方法有很多,这里给出了一些有用方法。 1....使用二维数组: 当所有字符串长度已知并且需要特定内存占用时,此方法很有用。字符串空间将在单个块中分配 这在 C 和 C++ 中都受支持。...同样,4 可能会被忽略,并且适当大小将由编译器计算。但是,必须给出第二个维度(在本例 10),以便编译器可以选择合适内存布局。 每个字符串都可以修改,但会占用第二维给出全部空间。

    1.8K30

    django实现模板字符串文字和自动转义

    本文只考虑模板字符串,不考虑字符串带标签情况。 模板字符串文字不会自动转义,因为这里默认模板作者已经正确书写模板内容。...{{ data|default:”This is a string literal.” }} 如果我们在data不存在时,显示默认文字“3 < 2”,则代码如下: {{ data|default:...”3 < 2″ }} 注意:不应该写成如下形式 {{ data|default:”3 < 2″ }} 虽然,两种方式页面显示结果一致,均为3 < 2,但是后者超出了模板作者控制范围。...补充知识:Django view通过render将“字符串”传给页面插件时,值被截断问题 view.py中代码: # startTime = request.POST.get('startTime'...以上这篇django实现模板字符串文字和自动转义就是小编分享给大家全部内容了,希望能给大家一个参考。

    4K30

    AndroidTextView实现分段显示不同颜色字符串

    关于TextView TextView是Android开发中最最常见控件之一,在API记录属性有很多,但实际开发,也遇到很多有趣需求,值得去尝试,所以记录下来,既可以给大家提供参考,同时自己需要时候也方便查找...最近开发过程中有个小小知识点,就是TextView显示内容需要分段显示不同颜色,如下图所示 ?...一般有三种实现方式 直接根据不同需要分段字符串,然后分别使用多个TextView来显示 使用spannablestring 使用Html 下面分别来简单介绍下三种方法 多个TextVew 这种方式简单粗暴...SpannableString可以精确控制一个长长字符串第几个到第几个字符样式 SpannableString spannableString = new SpannableString("jakjfkajfjaj...TextView) view.findViewById(R.id.tvContent); tvContent.setText(Html.fromHtml(content)); 以上就是TextView分段显示不同样式字符串方法

    3.8K30

    JAVA字符串数组做参数传递情况

    方法ch[] 数组和原始ch[]数组指向同一个数据,所以初始阶段ch[0]都指向’a’;接着对副本ch[0]进行新赋值变为‘g’。 所以运行结果: 原理参考下图 3....System.out.println("方法调用后str1值" + str1); } } 分析: 字符串是一个特殊数据类型,它底层是一个final 型char[]数组,属于无法更改...,所以字符串在作为参数传递时,可以当做一个特殊数组进行操作,同样它也是将复制一份原本对象引用给了副本,此时副本对象引用和原本对象引用都指向原始字符串位置,也就是str2在刚开始初始化时它指向地址和原对象...”;s3=new StringBuffer(”new”);这个操作要注意,此时相当于给了s3一个新对象引用,s3指向一个字符串“new”位置,所以此时s3=“new”,s4=“hello” (3...④关于字符串做参数,也是看它参数变量指向是否发生了变化,因为String底层final类型char[]原因,当你在String s = “aaa”还是String s = new String(

    1.5K30

    格式化httpheader字符串数组(格式键值对或格式传header值用索引数组)

    格式键值对的话,方便取值 或格式传header值用索引数组,可以用于调用接口传值使用 /**格式化httpheader字符串数组 * @param $header_str header头字符串...* @param int $is_need_key 是否分割成键值对数组,方便取出每一项值,仅仅分割换行不分割键值对的话这个数据格式刚好可以抓数据时候传header * @return array...返回数组 */ function http_header_to_arr($header_str,$is_need_key=0){ $header_list = explode("\n", $...(base64_decode($header_arr['Content-MD5'])); } return $header_arr; } 未经允许不得转载:肥猫博客 » 格式化httpheader...字符串数组(格式键值对或格式传header值用索引数组)

    1.6K40

    c给字符数组字符串指针赋值方法总结

    在C语言中把字符串当作数组来处理,因此,对字符串限制方式和对数组一样,特别是,它们都不能用C语言运算符进行复制和比较操作。 直接尝试对字符串进行复制或比较操作会失败。...例如,假定str1和str2有如下声明: char str1[10], str2[10]; 利用=运算符来把字符串复制到字符数组是不可能: str1 = “abc”; str2 = str1...; C语言把这些语句解释一个指针与另一个指针之间(非法)赋值运算。...但是,使用=初始化字符数组是合法: char str1[10] = “abc”; 这是因为在声明,=不是赋值运算符。...试图使用关系运算符或判等运算符来比较字符串是合法,但不会产生预期结果: if (str1==str2) … 这条语句把str1和str2作为指针来进行比较,而不是比较两个数组内容。

    5.8K30

    数组字符串匹配(难度:简单)

    一、题目 给你一个字符串数组 words ,数组每个字符串都可以看作是一个单词。请你按 任意 顺序返回 words 是其他单词字符串所有单词。...三、解题思路 3.1> 思路1:暴力破解(一) 首先,我们以双层for循环来遍历对比数组字符串,例如,当第一层for循环遍历到“leetcoder”时,我们会将其遍历“leetcoder”之后所有字符串...,依然是采用暴力破解方式,但是与第一种不同点是,从数组第一个字符串开始,每次获取一个字符串,然后与其他字符串进行对比(即:除了自己),那么只要发现这个字符串是对方子串了,那么就终止遍历,即可将这个子串加入到...首先,我们获取数组第一个字符串“leetcoder”,让它与其他字符串作比较,来判断“leetcoder”是否是对方子串,那么遍历完其他字符串之后,发现,都不满足成为对方子串条件,那么本次循环结束...那么第二个我们拿“leetcode”去与其他字符串做比较,当对比数组第一个字符串“leetcoder”时候,就满足了“leetcode”是“leetcoder”判断条件,因为已经确定了”leetcode

    56320

    015:为什么Java字符串对象是不可变

    字符串对象不可变好处 字符串共享 字符串常量池:字符串常量池是JVM一块特殊区域(1.7之前存放在perm区,1.8之后存放在堆上),用来存放字符串对象值。...在JVM字符串是不可变,因此JVM对于相同字符序列,可以只保存一份,这个特性称之为“interning”。由于字符串是JVM中最常见对象,因此实现字符串共享可以节省很多堆内存。 ?...Java类加载器加载类时候,也是根据类名字去文件系统对应路径去查找,类名称、对应路径,都是使用字符串对象存储。...将字符串对象设计不可变,就意味着这个敏感信息一经生成就不会被改变(有点现在流行区块链思路)。 常见安全检查流程有两个步骤:(1)校验安全信息;(2)进行敏感操作。...假设字符串变量str = "hello"被多个线程同时使用,如果在某个线程对str赋了新字符串值,那么就会在字符串常量池中生成一份新字符串,不会有并发争用。

    62130
    领券