呈现标记的模板文字时的额外替换

时间:2018-12-19 17:45:42

标签: javascript ecmascript-6 template-literals tagged-templates

我刚刚开始使用模板文字和带标签的模板文字。但是在尝试渲染模板文字时遇到了一个问题,因为它会带来额外的替代,我想知道它的来源。

这是我尝试过的:

我的数据

var data = {
    login: "john_12",
    name: "John",
    bio: "developer",
    email: "jdev@mail.com"
}

我的标签功能

function replaceNullData(strings, ...parts) { 
     var checkedMarkup = ""; 
     strings.forEach((string, index) => { 
         if (!parts[index]){ 
             parts[index] = "data no available"; 
         } 
         checkedMarkup += string + parts[index]; 
     }); 

     return checkedMarkup; 
 }

我的模板文字

var summaryMarkup = replaceNullData`
         <div>
             <p>Username: ${data.login}</p>
         </div>
         <div>
             <p>Name: ${data.name}</p>
         </div>
         <div>
             <p>Bio: ${data.bio}/<p>
         </div>
         <div>
             <p>Email: ${data.email}</p>
         </div>
     `; 

现在,如果我做console.log(summaryMarkup);,我会得到:

     <div> 
         <p>Username: john_12</p> 
     </div> 
     <div> 
         <p>Name: John</p> 
     </div> 
     <div> 
         <p>Bio: developer/<p> 
     </div> 
     <div> 
         <p>Email: jdev@mail.com</p> 
     </div> 
 data no available <------- THIS IS WHAT SHOULDN'T APPEAR

最后还有一个额外的“数据不可用”。就像标记函数收到了6个parts(替换或表达式)而不是5。

我在这里想念什么?

1 个答案:

答案 0 :(得分:1)

您的parts.length是您期望的长度,但是请注意,您要迭代strings,而不是partsstrings.length === parts.length + 1,因此您正在访问parts越界。而是迭代parts并在迭代之外附加最后一个字符串:

function replaceNullData(strings, ...parts) { 
    var checkedMarkup = ""; 
    parts.forEach((part, index) => {
        if (part == null) { // because false, 0, NaN, and '' should be "available"
            part = "data not available";
        }

        checkedMarkup += strings[index] + part;
    });

    return checkedMarkup + strings[strings.length - 1]; // manually append last string
}