//监听数据表格工具条
        table.on('tool(contentList)', function(obj){ //注:tool是工具条事件名,test是table原始容器的属性 lay-filter="对应的值"
            var data = obj.data //获得当前行数据
                ,layEvent = obj.event; //获得 lay-event 对应的值
            if(layEvent === 'detail'){
                x_content_detail('小说详情','content-detail.html',data,600,500);
            } else if(layEvent === 'del'){
                layer.confirm('真的删除行么', function(index){
                    x_content_delete('/novel/delete',data.novelId);
                    layer.close(index);
                });
            } else if(layEvent === 'edit'){
                x_content_edit('编辑小说','content-edit.html',data,600,500);
            }
        });
 
 
layui弹出层回显代码:
title:弹出层标题
url:弹出层html页面
data:回显数据
w:宽度
h:高度
 
function x_content_edit(title, url, data, w, h) {
    if (title == null || title == '') {
        title = false;
    }
    ;
    if (url == null || url == '') {
        url = "404.html";
    }
    ;
    if (w == null || w == '') {
        w = 800;
    }
    ;
    if (h == null || h == '') {
        h = ($(window).height() - 50);
    }
    ;
    layer.open({
        type: 2,    //iframe层
        area: [w + 'px', h + 'px'],
        fix: false, //不固定
        btn: ['确认', '取消'],//弹出层按钮
        maxmin: true,
        shadeClose: true,
        shade: 0.4,
        title: title,
        offset: '50px',
        content: url,
        success: function (layero, index) {//弹出层打开后的回调函数
            var body = layer.getChildFrame('body', index);//获取弹出层的dom元素
            result = JSON.stringify(data);
            result = $.parseJSON(result);
            $.each(result, function (item) {
                body.find('#A_' + item).val(result[item]);//给弹出层页面赋值,id为对应弹出层表单id
                if (item == 'contentId') {
                    body.find('#B_contentId').val(result[item]);//这里是为动态select赋值,在弹出层创建隐藏元素
                } else if (item == 'type') {
                    body.find('#B_type').val(result[item]);
                } else if (item == 'recommendFlag') {
                    body.find('#B_recommendFlag').val(result[item]);
                }
            });
        },
        yes: function (index, layero) {//点击“确认”按钮后触发的事件
            var data = {};
            var body = layer.getChildFrame('body', index);
            var form = body.find("#novelUpdate").serializeArray();//获取指定id的表单
            $.each(form, function () {
                data[this.name] = this.value;
            });
            data = JSON.stringify(data);
            var content = {'novelJson': data};
            $.post('/novel/update', content, function (rec) {//得到数据提交到后端进行更新
                if (rec.code == 0) {
                    layer.alert(rec.msg, {icon: 6}, function (index) {
                        layer.close(index);
                    });
                    layui.use('table', function () {
                        var table = layui.table;
                        table.reload('contentList', {
                            url: '/novel/novelList' //数据接口,更新成功后刷新数据表格
                        });
                    });
                } else {
                    layer.alert(rec.msg, {icon: 5}, function (index) {
                        layer.close(index);
                    });
                }
                layer.close(index);
            }, 'json');
            return false;
 
        }
    });
}
 
 
从后台读取数据渲染到弹出层的select中,并设置默认选中值:
 
function showNovelType() {
    layui.use('form',function () {
        $ = layui.jquery;
        var form = layui.form;
        $.ajax({
            type:'get',
            url:'/common/getNovelType', //后端接口
            dataType:'json',
            success:function (rec) {
                if(rec['code']==0){
                    var novelType=document.getElementById('A_type');
                    var B_type=document.getElementById('B_type');
                    $.each(rec.data,function(i,item){
                        var option=document.createElement("option"); //创建option标签
                        option.setAttribute("value",item['typeId']);//设置value值
                        if(!B_type) {
                            //要同时判断 null 和 undefined
                        }else {
                            if(item['typeId']==B_type.value) {
                                option.setAttribute("selected",'true');//设置选中状态
                            }
                        }
                        option.innerText=item['typeName'];//显示text内容
                        novelType.appendChild(option);
                        form.render('select');//重新渲染
                    })
                }
            }
        })
    })
}
 
function showRecommendPotion() {
    layui.use('form',function () {
        $ = layui.jquery;
        var form = layui.form;
        $.ajax({
            type:'get',
            url:'/common/getRecommendPosition',
            dataType:'json',
            success:function (rec) {
                if(rec['code']==0){
                    var recommendPotion=document.getElementById('A_recommendFlag');
                    var B_recommendFlag=document.getElementById('B_recommendFlag');
                    $.each(rec.data,function(i,item){
                        var option=document.createElement("option");
                        option.setAttribute("value",item['recommendId']);
                        if(!B_recommendFlag) {
                            //要同时判断 null 和 undefined
                        }else{
                            if(item['recommendId']==B_recommendFlag.value) {
                                option.setAttribute("selected",'true');
                            }
                        }
                        option.innerText=item['recommendName'];
                        recommendPotion.appendChild(option);
                        form.render('select');
                    })
                }
            }
        })
    })
}
 
function showContentProvider() {
    layui.use('form',function () {
        $ = layui.jquery;
        var form = layui.form;
        $.ajax({
            type:'get',
            url:'/contentProvider/getAllProviders',
            dataType:'json',
            success:function (rec) {
                if(rec['code']==0){
                    var A_contentId=document.getElementById('A_contentId');
                    var B_contentId=document.getElementById('B_contentId');
                    $.each(rec.data,function(i,item){
                        var option=document.createElement("option");
                        option.setAttribute("value",item['contentId']);
                        if(!B_contentId) {
                            //要同时判断 null 和 undefined
                        }else{
                            if(item['contentId']==B_contentId.value) {
                                option.setAttribute("selected",'true');
                            }
                        }
                        option.innerText=item['contentName'];
                        A_contentId.appendChild(option);
                        form.render('select');
                    })
                }
            }
        })
    })
}
 

layui在open弹出层回显,解决动态select数据回显问题的更多相关文章

  1. layui如何自定义弹出层关闭事件

    在某些业务场景下,我们需要自定义弹出层关闭事件,代码示例如下: layui.use('layer', function () { var layer = layui.layer; layer.open ...

  2. layui如何隐藏弹出层关闭的按钮

    layui默认弹出层是带有关闭按钮的,但是在某些场景我们不需要layui的关闭按钮,这时只需添加closeBtn :0即可 效果图如下: 示例代码如下: layui.use('layer', func ...

  3. Layui弹出层、日期和时间选择、即时通讯、分页

    Layui弹出层.日期和时间选择.即时通讯.分页 弹层组件文档 - layui.layer 对于弹出层的感觉是:layer 至今仍作为 layui 的代表作,她的受众广泛并非偶然,而是这数年来的坚持. ...

  4. 微擎使用post提交,并显示弹出层

    微擎使用post提交,并显示弹出层 function changeStatus(id, status) { // 提交数据 var id = parseInt(id); var status = pa ...

  5. layui弹出层处理(获取、操作弹出层数据等)

    要点: 字符串被渲染为弹窗层之后,回自动转换为DOM,可以使用jq进行各种操作 <!DOCTYPE html> <html> <head> <meta cha ...

  6. LayUI之弹出层

    1.导入插件 layui使用需要导入layui的js和css: <link rel="stylesheet" href="layui/css/layui.css&q ...

  7. 权限管理系统之LayUI实现页面增删改查和弹出层交互

    由于对LayUI框架不太熟悉,昨天抽空看了下LayUI的文档,今天在网上找了使用LayUI进行增删改查相关内容,自己照葫芦画了个瓢,画瓢部分不是很难,主要是下午遇到了一个弹出层的问题耗时比较久. 同一 ...

  8. 弹出层-layui

    type 0(信息框,默认)1(页面层)2(iframe层)3(加载层)4(tips层) 弹出层 //winIndex存储弹出层的index,以便关闭弹出层时使用 function openWindo ...

  9. layui关闭弹出层

    layui关闭弹出层,今天我在vscode中使用p parent.layer.closeAll()发现没效果 换成layer.closeAll()就解决了这个问题. 由此我觉得关闭layui关闭弹出层 ...

随机推荐

  1. numpy, matplotlib库学习笔记

    Numpy库学习笔记: 1.array()   创建数组或者转化数组 例如,把列表转化为数组 >>>Np.array([1,2,3,4,5]) Array([1,2,3,4,5]) ...

  2. C# Winform ComBox三种赋值方式

    https://www.cnblogs.com/ingstyle/p/4815303.html 第一种方法: DataTable dt = new DataTable(); dt.Columns.Ad ...

  3. idea工具和激活码获取

    1.下载最新的idea https://blog.csdn.net/mashuai720/article/details/79389314 2.获取激活码 最后一个有效,亲测 https://blog ...

  4. Java 处理word文档后在前端展示

    最新新开发的这个项目需要使用word文档并要求能在前端页面上带格式展示,由于项目不是内部使用,所以不考虑插件类的处理模式,都必须要本地处理完成,前端不需要做什么更新或者说安装就能直接访问,类似于百度文 ...

  5. GeoJson

    几何对象.特征对象.特征对象集合.

  6. C、C++中的static和extern关键字

    1.首先,关于声明和定义的区别 这种写法(函数原型后加;号表示结束的写法)只能叫函数声明而不能叫函数定义,只有带函数体的声明才叫定义,比如下面 只有分配存储空间的变量声明才叫变量定义,其实函数也是一样 ...

  7. HTML5本地存储之本地数据库篇

    <!DOCTYPE HTML> <html> <head> <meta charset="utf-8" /> <title&g ...

  8. MySQL优化查询 5.7版本

    1. 变更参数 : query_cache_type 如果何配置查询缓存: query_cache_type 这个系统变量控制着查询缓存工能的开启的关闭.query_cache_type=0时表示关闭 ...

  9. python+selenium的web自动化测试之二(Jenkins自动执行)

    上一篇需要手工去到cmd下执行脚本,不符合自动化测试的终极目标.现我们集成到Jenkins上,通过Jenkins一键执行或定时任务执行. 参考: https://www.cnblogs.com/ces ...

  10. ssh跳过knownhost文件

    在平时工作中,有时候需要SSH登陆到别的Linux主机上去,但有时候SSH登陆会被禁止,并弹出如下类似提示: @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ ...