使用es6模板字符串实现循环,并在循环中做判断

使用es6模板字符串实现循环,做判断

在模板字符串中,遍历数组,生成循环结构

var selectList= [
    {value: 'text',label: '文本框'},
    {value: 'checkbox',label: '复选框'},
    {value: 'radio', label: '单选框'},
    {value: 'textarea',label: '文本域'},
    {value: 'select',label: '下拉框'},
    {value: 'files',label: '附件'},
    {value: 'label',label: '不可编辑文本框'},
    {value: 'datetime',label: '日期选择器'}
]
  var html = `<table border="1" cellpadding="1" cellspacing="1" style="width: 90%;margin: 0">
            <tbody>
                ${arrChecked.map((item,index) => { 
                  selectList.forEach(_item => {
                    if (item.Type == _item.value) {
                      item.label = _item.label
                    }
                  })
                  return (index%2==0 ? '<tr>' : '')+`<td style="width: 130px; text-align: right;">${item.IndexName +':'+' &nbsp;'}</td>
                          <td style="width: 100px;"><input value=${item.label || ''} /></td>`+(index%2!=0 ? '</tr>' : '')
                  }).join('')}
            </tbody>
        </table>
      <p>&nbsp;</p>`

index %2 == 0 进行判断是否换行显示,使一行显示两个输入框
实现效果
在这里插入图片描述

注意

  1. 主要是map的使用,需要用map,将值return出去,如果使用foreach则不报错一直返回undefined
  2. 不添加 join(")时,在 标签中间会多一个逗号,这是因为当大括号中的值不是字符串时,会将其转为字符串.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值