简单的模板引擎

1.字符串的拼接

  • 举例:
let songs = [
    {name: '刚刚好1',singer: '薛之谦1'},
    {name: '刚刚好2',singer: '薛之谦2'},
    {name: '刚刚好3',singer: '薛之谦3'},
    {name: '刚刚好4',singer: '薛之谦4'},
    {name: '刚刚好5',singer: '薛之谦5'}
]
let html = '<div class="ct">'
html += '<h1>热歌榜</h1><ul>'

let i
for(i = 0;i < songs.length;i++){
    html += '<li>'+ songs[i].name +' - '+ songs[i].singer +'</li>'
}
html += '</ul></div>'

document.body.innerHTML = html

2. jQuery方式 构建 DOM 对象

let songs = [
    {name: '刚刚好1',singer: '薛之谦1'},
    {name: '刚刚好2',singer: '薛之谦2'},
    {name: '刚刚好3',singer: '薛之谦3'},
    {name: '刚刚好4',singer: '薛之谦4'},
    {name: '刚刚好5',singer: '薛之谦5'}
]
let $div = $('<div class="ct"></div>')
let $ul = $('<ul></ul>')

$(songs).each((index,item) => {
    let $li = $('<li>'+ item.name +'-'+ item.singer +'</li>')
    $ul.append($li)
})

$div.append('<h1>热歌榜</h1>')
$div.append($ul)
$('body').append($div)

3. string formate

let songs = [
    {name: '刚刚好1',singer: '薛之谦1'},
    {name: '刚刚好2',singer: '薛之谦2'},
    {name: '刚刚好3',singer: '薛之谦3'},
    {name: '刚刚好4',singer: '薛之谦4'},
    {name: '刚刚好5',singer: '薛之谦5'}
]

function stringFormat (string) {
    // console.log(arguments)  // ["hi,{0}", "tian", callee: ƒ, Symbol(Symbol.iterator): ƒ]
    // 拿到arguments 除了第一项的其他项
    let parmas = [].slice.call(arguments,1)
    console.log(parmas) // ["tian", "yang"]

    // 将 string 中的 {n} 替换成 parmas{n}
    let regex = /\{(\d+)\}/g // 正则匹配 {n}
    string = string.replace(regex,function () {
        console.log(arguments)
        // 拿到 n 的下标
        let index = arguments[1]
        // 根据下标找到parmas里面的项
        return parmas[index]
    })

    return string
}


console.log(stringFormat('hi,{0} and {1}', 'tian','yang')) // 替换结果:hi,tian and yang
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容