layui使用模板渲染数据

简介: layui使用模板渲染数据

1.定义容器(用于填充渲染后的script)

<div id="view" style="display: none;"></div>

2.定义script模板

<script type="text/html" id="myModal">
    <div style="padding: 20px;">
        <form id="userForm" class="layui-form" lay-filter="editWin">
            <input type="hidden" id="uid" name="uid" value={{=d.id}}>
            
            <div class="layui-form-item">
                <label class="layui-form-label">角色类别:</label>
                <div class="layui-input-block">
                    <select id="roleTypeSelect" class="layui-select">
                        <option value="-1">请选择角色类别</option>
                        {{# layui.each(d.roleTypeList, function(index, item){     }}
                            {{#  if(d.roleType == item.dicVal ){   }}
                                <option value="{{ item.dicVal}}" selected="selected">{{ item.dicName}}</option>
                            {{# }else{ }}
                                <option value="{{ item.dicVal}}" >{{ item.dicName}}</option>
                            {{# } }}
                        {{# });  }}
                    </select>
                </div>
            </div>
            
        </form>
    </div>
</script>

3.laytpl动态绑定渲染script

// 此处模拟展示data数据

{

   "roleTypeList" : [

       {"dicVal" : "01" , "dicName" : "管理员"},

       {"dicVal" : "02" , "dicName" : "游客"},

       {"dicVal" : "03" , "dicName" : "普通用户"},

   ],

   "id" : 7,

   "roleType" : "03"

}

 

var scriptHtml = document.getElementById("myModal").innerHTML;
var view = document.getElementById("view");
 
// 通过data数据渲染script模板
laytpl(scriptHtml).render(data, function (html) {
    view.innerHTML = html;
});
 
// layui弹框,类似model模态框
layer.open({
    type: 1,
    title: '弹框名称',
    offset: '20px',
    area: ['500px', '330px'],
    closeBtn: false,
        content: $("#view")
    })
 
form.render('select');  // layui中动态设置html的某个类型标签时,需要layui.render('type')刷新

参考地址

Layui - 经典开源模块化前端 UI 组件库

laytpl标签: {{# }}
 
参数格式:
{
    "field" : "值",
    "keyList" : [
        {"field":"值1"},
        {"field":"值2"}
    ]
}
 
// 模板中使用d表示传入参数
 
1.输出字段,不转义html
    {{ d.field }}
 
2.输出字段,转义html
    {{= d.field }}
 
3.js表达式
    {{#     if(d.field=="XXX"){     }}
        // 输出值
    {{#     }         }}
 
4.遍历集合
    {{# layui.each(d.keyList, function(index, item){     }}
        {{# item.field }}
    {{# });  }}

 


相关文章
|
JavaScript
Layui 弹层组件 - 基础参数3
Layui 弹层组件 - 基础参数3
82 0
|
JavaScript 前端开发
Layui 弹层组件 - 基础参数1
Layui 弹层组件 - 基础参数1
102 0
|
6月前
|
缓存 前端开发
两个可以提升列表性能渲染的CSS
两行 CSS 让长列表性能渲染提升 7 倍
28 3
|
5月前
ElementUI——elementui2.0表格支持render渲染
ElementUI——elementui2.0表格支持render渲染
188 0
|
5月前
|
JavaScript 前端开发
js如何渲染页面内容
js如何渲染页面内容
45 0
|
8月前
|
Python
渲染模板
【2月更文挑战第21天】渲染模板。
34 1
|
8月前
|
移动开发 前端开发
【通用CSS模板】移动端H5页面统一样式.css
【通用CSS模板】移动端H5页面统一样式.css
|
8月前
|
JavaScript 前端开发
js制作动态表单
js制作动态表单
57 0
|
8月前
|
缓存 自然语言处理 JavaScript
Vue 3 渲染机制解密:从模板到页面的魔法
Vue 3 渲染机制解密:从模板到页面的魔法
387 0
|
前端开发 Java
使用layui快速渲染表格
使用layui快速渲染表格
86 0