zoukankan      html  css  js  c++  java
  • vue element组件实现点击加号新增一行,点击减号删除一行

    最近项目中用到了通过VUE element组件实现点击加号新增一行,点击减号删除一行,

     废话不多说了,直接上代码,

    HTML部分:

      <i class="el-icon-plus clolos1" @click="addPdfFile"></i>//加号(增加一行)
                <div class="add_pdf" v-for="(item, index) in addPdf" :key="index">
                    <div v-show="index !== 0">
                        <i class="el-icon-delete clolos clolos3" @click="deletePdf(index)"></i>//减号(删除一行)
                    </div>
                    <span>新增PDF</span>
                    <el-row :gutter="20">
                        <el-col :span="10">
                            <div>
                                <el-form-item label="语言:" prop="language">
                                    <el-select v-model="form.language" placeholder="请选择">
                                        <el-option label="英语" value="英语"></el-option>
                                        <el-option label="日语" value="日语"></el-option>
                                        <el-option label="德语" value="德语"></el-option>
                                    </el-select>
                                </el-form-item>
                            </div>
                        </el-col>
                        <el-col :span="10">
                            <div>
                                <el-form-item label="产品类别:" prop="productCategory">
                                    <el-select v-model="form.productCategory" placeholder="请选择">
                                        <el-option label="呼吸机" value="呼吸机"></el-option>
                                        <el-option label="麻醉机" value="麻醉机"></el-option>
                                        <el-option label="手术灯" value="手术灯"></el-option>
                                    </el-select>
                                </el-form-item>
                            </div>
                        </el-col>
                    </el-row>
                    <el-row :gutter="22">        //将两个文本框放在了同一行
                        <el-col :span="10">
                            <div>
                                <el-form-item label="彩页名称:" prop="colorName">
                                    <el-input type="text" style="165px" v-model="form.colorName"></el-input>
                                </el-form-item>
                            </div>
                        </el-col>
                        <el-col :span="6">
                            <div>
                                <el-form-item label="彩页图片:" prop="colorImage">
                                    <el-upload
                                        class="upload-demo"
                                        action="https://jsonplaceholder.typicode.com/posts/"
                                        :on-preview="handlePreview"
                                        :on-remove="handleRemove"
                                        :before-remove="beforeRemove"
                                        multiple
                                        :limit="3"
                                        :on-exceed="handleExceed"
                                        v-model="form.colorImage"
                                    >
                                        <el-button size="small" type="primary">点击上传</el-button>
                                    </el-upload>
                                </el-form-item>
                            </div>
                        </el-col>
                    </el-row>
                </div>

    js部分:

    export default {
        data() {
            return {
                addPdf: [1],
            };
    css部分:
    <style lang='less' scoped>
    .clolos1 {//增加按钮样式
         13px;
        height: 30px;
        background: #29affb;
        line-height: 30px;
        padding: 0 10px;
        border-radius: 15px;
        color: #fff;
        position: absolute;
        margin-left: 65.35%;
        margin-top: 8.48%;
        z-index: 1;
    }
    .clolos2 {
         13px;
        height: 30px;
        background: #29affb;
        line-height: 30px;
        padding: 0 10px;
        border-radius: 15px;
        color: #fff;
        position: absolute;
        margin-left: 65%;
        margin-top: 7%;
    }
    .clolos3 {//删除按钮样式
         13px;
        height: 30px;
        background: red;
        line-height: 30px;
        padding: 0 10px;
        border-radius: 15px;
        color: #fff;
        position: absolute;
        margin-left: calc(100% + 40px);
        margin-top: 10%;
    }
    .add_pdf {    
        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.12), 0 0 6px rgba(0, 0, 0, 0.04);
         80%;
        position: relative;
        margin-top: 3%;
    }
    .basicinformation {
        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.12), 0 0 6px rgba(0, 0, 0, 0.04);
         80%;
        position: relative;
    }
    </style>

    写到这里估计大大多数小伙伴应该能领悟到了这个功能是如何实现了吧,我是新手小白,
     
    立志于为更多新手小白写下更简单、更通俗易懂、更一目了然的代码。希望大家多多关注我
  • 相关阅读:
    超链接
    Image中的alt
    预格式
    json字符串转json对象,json对象转换成java对象
    google-gson 解析json
    java HTTP请求工具
    JS文件中获取contextPath的方法
    eclipse中安装freemarker插件及ftl使用freemarker编辑器
    MyBatis 传入参数之parameterType
    typeAliases别名
  • 原文地址:https://www.cnblogs.com/bailing80/p/13401843.html
Copyright © 2011-2022 走看看