在vue中动态添加商品SKU

1、需要在项目中引用jquery,效果如下图:(商品规格是动态从后台获取的,每次勾选会去组合)

2、多选框代码结构如下:

<!--SKU-->
                <div class="wrap" v-if="this.obj.length > 0">
                    <div v-if="goodsId == '' || goodsId == undefined || goodsId == null">
                        <div class="control-group choose_config">
                            <el-form-item label="商品规格">
                                <div class="controls">
                                    <div v-for="(item,index) in obj" :key="index">
                                        <h3 class="Father_Title">{{Object.keys(item).join()}}</h3>
                                        <ul :class="'Father_Item' + ' ' + 'Father_Item'+index">
                                            <li v-for="val,index in item[Object.keys(item).join()]" :key="index"><label><input
                                                id="Checkbox0" type="checkbox" @change="init"
                                                class="checkbox check_item" :value="val">{{val}}</label></li>
                                        </ul>
                                        <br>
                                    </div>
                                </div>
                            </el-form-item>
                        </div>
                        <!-- 生成表格 -->
                        <div class="control-group mt10">
                            <el-form-item>
                                <div class="controls" id="createTable"></div>
                            </el-form-item>
                        </div>
                    </div>
                </div>
                <!--SKU-->
// 商品数据结构如下,循环渲染,每次点击多选框生成表格。

      obj = [
       {12: ["22"]},
       {出行人数: ["单人", "三人行"]},
       {团期: ["01/30", "02/12", "02/15", "01/20"]}
     ]

3、动态生成表格:

// 添加商品规格列表
            init() {
                $('.checkbox', parent).each(function () {
                    var bCheck2 = true;
                    if (_this.hasClass('check_all')) {
                        if (_this.get(0).checked) {
                            bCheck2 = true;
                            $('.check_item', parent).prop('checked', bCheck2);
                        } else {
                            bCheck2 = false;
                            $('.check_item', parent).prop('checked', bCheck2);
                        }
                        return false;
                    } else {
                        if ((!this.checked) && (!$(this).hasClass('check_all'))) {
                            bCheck2 = false;
                            $('.check_all', parent).prop('checked', bCheck2);
                            return false;
                        }
                    }
                    $('.check_all', parent).prop('checked', bCheck2);
                });
                this.Creat_Table();
            },
            Creat_Table() {
                this.hebingFunction();
                var SKUObj = $('.Father_Title');
                var arrayTile = new Array(); // 表格标题数组
                var arrayInfor = new Array(); // 盛放每组选中的CheckBox值的对象
                var arrayColumn = new Array(); // 指定列,用来合并哪些列
                var bCheck = true; // 是否全选,只有全选,表格才会生成
                var columnIndex = 0;
                $.each(SKUObj, function (i, item) {
                    arrayColumn.push(columnIndex++);
                    arrayTile.push(SKUObj.eq(i).text().replace(':', ''));
                    var itemName = '.Father_Item' + i;
                    var bCheck2 = true; // 是否全选
                    
                    // 获取选中的checkbox的值
                    var order = new Array();
                    $(itemName + ' .check_item:checked').each(function () {
                        order.push($(this).val());
                    });
                    
                    arrayInfor.push(order);
                    if (order.join() == '') {
                        bCheck = false;
                    }
                })
                
                // 开始生成表格
                if (bCheck) {
                    $('#createTable').html('');
                    var table = $('<table id="process" class="columnList"></table>');
                    table.appendTo($('#createTable'));
                    var thead = $('<thead></thead>');
                    thead.appendTo(table);
                    var trHead = $('<tr></tr>');
                    trHead.appendTo(thead);
                    // 创建表头
                    var str = '';
                    $.each(arrayTile, function (index, item) {
                        str += '<th width="100">' + item + '</th>';
                    })
                    str += '<th  width="">商品价格</th><th width="">市场价格</th><th width="">库存</th><th width="">已售销量</th><th width="">库存预警值</th>';
                    
                    trHead.append(str);
                    var tbody = $('<tbody></tbody>');
                    tbody.appendTo(table);
                    var zuheDate = this.doExchange(arrayInfor);
                    if (zuheDate.length > 0) {
                        //创建行
                        $.each(zuheDate, function (index, item) {
                            var td_array = item.split(',');
                            var tr = $('<tr></tr>');
                            tr.appendTo(tbody);
                            var str = '';
                            $.each(td_array, function (i, values) {
                                str += '<td>' + values + '</td>';
                            });
                            str += '<td ><input  value="" class="inpbox txt1 inpbox-mini" type="text"></td>';
                            str += `<td ><input  value="" class="inpbox txt2 inpbox-mini" type="text"></td>`;
                            str += '<td ><input  value="" class="inpbox txt3 inpbox-mini" type="text"></td>';
                            str += '<td ><input  value="0" disabled="disabled" class="inpbox txt4 inpbox-mini" type="text"></td>';
                            str += '<td ><input  value="" class="inpbox txt5 inpbox-mini" type="text"></td>';
                            tr.append(str);
                        });
                    }
                    
                    //结束创建Table表
                    arrayColumn.pop(); //删除数组中最后一项
                    //合并单元格
                    $(table).mergeCell({
                        // 目前只有cols这么一个配置项, 用数组表示列的索引,从0开始
                        cols: arrayColumn
                    });
                } else {
                    //未全选中,清除表格
                    document.getElementById('createTable').innerHTML = "";
                }
            },
            hebingFunction: function () {
                $.fn.mergeCell = function (options) {
                    return this.each(function () {
                        var cols = options.cols;
                        for (var i = cols.length - 1; cols[i] != undefined; i--) {
                            mergeCell($(this), cols[i]);
                        }
                        dispose($(this));
                    })
                };
                
                function mergeCell($table, colIndex) {
                    $table.data('col-content', ''); // 存放单元格内容
                    $table.data('col-rowspan', 1); // 存放计算的rowspan值 默认为1
                    $table.data('col-td', $()); // 存放发现的第一个与前一行比较结果不同td(jQuery封装过的), 默认一个"空"的jquery对象
                    $table.data('trNum', $('tbody tr', $table).length); // 要处理表格的总行数, 用于最后一行做特殊处理时进行判断之用
                    // 进行"扫面"处理 关键是定位col-td, 和其对应的rowspan
                    $('tbody tr', $table).each(function (index) {
                        // td:eq中的colIndex即列索引
                        var $td = $('td:eq(' + colIndex + ')', this);
                        // 获取单元格的当前内容
                        var currentContent = $td.html();
                        // 第一次时走次分支
                        if ($table.data('col-content') == '') {
                            $table.data('col-content', currentContent);
                            $table.data('col-td', $td);
                        } else {
                            // 上一行与当前行内容相同
                            if ($table.data('col-content') == currentContent) {
                                // 上一行与当前行内容相同则col-rowspan累加, 保存新值
                                var rowspan = $table.data('col-rowspan') + 1;
                                $table.data('col-rowspan', rowspan);
                                // 值得注意的是 如果用了$td.remove()就会对其他列的处理造成影响
                                $td.hide();
                                // 最后一行的情况比较特殊一点
                                // 比如最后2行 td中的内容是一样的, 那么到最后一行就应该把此时的col-td里保存的td设置rowspan
                                // 最后一行不会向下判断是否有不同的内容
                                if (++index == $table.data('trNum'))
                                    $table.data('col-td').attr('rowspan', $table.data('col-rowspan'));
                            }
                            // 上一行与当前行内容不同
                            else {
                                // col-rowspan默认为1, 如果统计出的col-rowspan没有变化, 不处理
                                if ($table.data('col-rowspan') != 1) {
                                    $table.data('col-td').attr('rowspan', $table.data('col-rowspan'));
                                }
                                // 保存第一次出现不同内容的td, 和其内容, 重置col-rowspan
                                $table.data('col-td', $td);
                                $table.data('col-content', $td.html());
                                $table.data('col-rowspan', 1);
                            }
                        }
                    })
                }
                
                // 同样是个private函数 清理内存之用
                function dispose($table) {
                    $table.removeData();
                }
            },
            doExchange: function (doubleArrays) {
                // 二维数组,最先两个数组组合成一个数组,与后边的数组组成新的数组,依次类推,知道二维数组变成以为数组,所有数据两两组合
                var len = doubleArrays.length;
                if (len >= 2) {
                    var arr1 = doubleArrays[0];
                    var arr2 = doubleArrays[1];
                    var len1 = arr1.length;
                    var len2 = arr2.length;
                    var newLen = len1 * len2;
                    var temp = new Array(newLen);
                    var index = 0;
                    for (var i = 0; i < len1; i++) {
                        for (var j = 0; j < len2; j++) {
                            temp[index++] = arr1[i] + ',' + arr2[j];
                        }
                    }
                    var newArray = new Array(len - 1);
                    newArray[0] = temp;
                    if (len > 2) {
                        var _count = 1;
                        for (var i = 2; i < len; i++) {
                            newArray[_count++] = doubleArrays[i];
                        }
                    }
                    return this.doExchange(newArray);
                } else {
                    this.form.array1 = doubleArrays[0] // 获得的组合数据,需要自己把后面的价格信息拼接上去
                    this.count = this.form.array1.length
                    return doubleArrays[0];
                }
            },
            di() { // 获取表格数据,并转换为JSON格式
                this.goodArr = []
                for (let i = 0; i < $('.txt1').length; i++) {
                    this.form.array1[i] += ',' + $('.txt1').eq(i).val()
                    this.form.array1[i] += ',' + $('.txt2').eq(i).val()
                    this.form.array1[i] += ',' + $('.txt3').eq(i).val()
                    this.form.array1[i] += ',' + $('.txt4').eq(i).val()
                    this.form.array1[i] += ',' + $('.txt5').eq(i).val()
                }
                
                for (let k = 0; k < this.form.array1.length; k++) {
                    let obj2 = {};
                    let str = this.form.array1[k].split(",");
                    let strSize = str.length;
                    let nameSize = this.obj.length;
                    let o = this.obj
                    if (strSize > 5) {
                        for (let j = 0; j < nameSize; j++) {
                            let first = Object.keys(o[j]).join()
                            obj2[first] = str[j]
                        }
                        obj2.price = str[strSize - 5];
                        obj2.marketPrice = str[strSize - 4];
                        obj2.stock = str[strSize - 3];
                        obj2.soldVolume = str[strSize - 2];
                        obj2.warnStock = str[strSize - 1];
                    }
                    this.goodArr.push(obj2);
                }
                console.log(this.goodArr)
            },
原文地址:https://www.cnblogs.com/liguiwang/p/8431156.html