专栏首页憧憬博客分享Vue使用Element实现增删改查+打包

Vue使用Element实现增删改查+打包

在我们进行项目开发期间,避免不了使用各式各样的组件,Element是由饿了么公司前端团队开源。样式精美、组件齐全、易于上手。

效果:

组件使用

我们利用vue-cli创建一个项目,然后只需要安装element-ui即可

安装:npm i element-ui -S

然后在main.js中引用一下样式即可,可以选择按需加载,我们这边因为是演示一下,所以不去进行调整,项目中如果使用到的组件不多,可以选择按需加载。

  • main.js
import Vue from 'vue';
import App from './App.vue';
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';

Vue.config.productionTip = false;

Vue.use(ElementUI);

new Vue({
  render: h => h(App),
}).$mount('#app')

然后我们在src/components下新建一个组件,用来写我们的展示组件,然后在app.vue中导入即可

  • app.vue
<template>
  <div id="app">
    <Creator content1="憧憬"/>
  </div>
</template>

<script>
import Creator from './components/Creator/Creator';

export default {
  name: 'app',
  components: {
    Creator
  }
}
</script>

我们首先先使用表格,将数据展示出来

  • Creator.vue
<template>
    <div class="Creator">
        <el-row :gutter="20">
            <el-col :span="6">
                <el-input v-model="content" placeholder="请输入内容"></el-input>
            </el-col>

            <el-col :span="2">
                <el-button type="primary">搜索</el-button>
            </el-col>
        </el-row>

        <div style="height: 20px"/>

        <el-row :gutter="10" type="flex" justify="center">
            <el-col :span="14">
                <el-table
                        :data="tableData"       // 声明列表使用的数据
                        :key="'zip'"            // 声明每一行的key
                        border
                        style="width: 100%">
                    <el-table-column
                            fixed
                            prop="date"
                            label="日期"
                            width="150">
                    </el-table-column>
                    <el-table-column
                            prop="name"         // 对应tableData里面的需要展示的键
                            label="姓名"
                            width="120">
                    </el-table-column>
                    <el-table-column
                            prop="province"
                            label="省份"
                            width="120">
                    </el-table-column>
                    <el-table-column
                            prop="city"
                            label="市区"
                            width="120">
                    </el-table-column>
                    <el-table-column
                            prop="address"
                            label="地址"
                            width="300">
                    </el-table-column>
                    <el-table-column
                            prop="zip"
                            label="邮编"
                            width="120">
                    </el-table-column>
                    <el-table-column
                            fixed="right"
                            label="操作"
                            width="160"
                            v-slot="scope"  // 获取每一行的数据
                     >
                        <template>       
                            <el-button @click="handleCreate(scope.row)"     type="text" size="small">添加</el-button>
                            <el-popconfirm
                                    confirmButtonText='好的'
                                    cancelButtonText='不用了'
                                    icon="el-icon-info"
                                    iconColor="red"
                                    title="这是一段内容确定删除吗?"
                                    @onConfirm="handleDelete(scope.row)"
                            >
                                <el-button slot="reference" type="text" size="small">删除</el-button>
                            </el-popconfirm>
                        </template>
                    </el-table-column>
                </el-table>
            </el-col>
        </el-row>


        <el-dialog title="添加用户" :visible.sync="dialogFormVisible">
        // rules指定表单验证规则
            <el-form :model="form" status-icon ref="ruleForm" :rules="rules" :label-position="'right'">
                <el-row :gutter="10">
                    <el-col :span="11">
                        <el-form-item prop="name" label="姓名" :label-width="formLabelWidth">
                            <el-input style="width: 200px" v-model="form.name" autocomplete="off"></el-input>
                        </el-form-item>
                    </el-col>
                </el-row>

                <el-row :gutter="10">
                    <el-col :span="11">
                        <el-form-item
                                prop="dates"    // 需要验证的字段 需要对应rules里面的键
                                label="日期"
                                :label-width="formLabelWidth"
                                :rules="[
                                    {required: true, message: '必须选择一个日期', trigger: 'blur'},
                                ]"          // 也可以直接写在item里面验证 也可以全放在rules。我这里是采取了两种方式
                        >
                            <el-date-picker
                                    v-model="form.dates"
                                    align="right"
                                    type="date"
                                    placeholder="选择日期"
                                    format="yyyy 年 MM 月 dd 日" // 展示数据的格式
                                    value-format="yyyy-MM-dd"       // 声明点击后的数据格式
                                    :picker-options="pickerOptions">
                            </el-date-picker>
                        </el-form-item>
                    </el-col>
                </el-row>
            </el-form>
            <div slot="footer" class="dialog-footer">
                <el-button @click="dialogFormVisible = false">取 消</el-button>
                <el-button type="primary" @click="onOk">确 定</el-button>
            </div>
        </el-dialog>

    </div>
</template>

<script>
    export default {
        props: {
            content1: {required: true, type: String}
        },

        data() {
        
            // 自定义验证函数 给name验证
            const validatName = (rule, value, callback) => {
                if (!value) return callback(new Error('名字不能为空'));
                if (value.length <= 0) return callback(new Error('最少一个字符'));
                return callback();
            };

            return {
                content: this.content1,
                tableData: [
                    {
                        date: '2016-05-02',
                        name: '王小虎',
                        province: '上海',
                        city: '普陀区',
                        address: '上海市普陀区金沙江路 1518 弄',
                        zip: 200331
                    }, {
                        date: '2016-05-04',
                        name: '王小虎',
                        province: '上海',
                        city: '普陀区',
                        address: '上海市普陀区金沙江路 1517 弄',
                        zip: 200332
                    }, {
                        date: '2016-05-01',
                        name: '王小虎',
                        province: '上海',
                        city: '普陀区',
                        address: '上海市普陀区金沙江路 1519 弄',
                        zip: 200333
                    }, {
                        date: '2016-05-03',
                        name: '王小虎',
                        province: '上海',
                        city: '普陀区',
                        address: '上海市普陀区金沙江路 1516 弄',
                        zip: 200334
                    }],

                formLabelWidth: '120px',

                // 控制模态是否展示
                dialogFormVisible: false,
                form: {
                    name: '',
                    dates: null,
                },

                // 对picker组件的扩展
                pickerOptions: {
                    // 将之后的时间禁用 不然选择
                    disabledDate(time) {
                        return time.getTime() > Date.now();
                    },
                    
                    // 增加 今天 昨天 一周前的快速选项
                    shortcuts: [{
                        text: '今天',
                        onClick(picker) {
                            picker.$emit('pick', new Date());
                        }
                    }, {
                        text: '昨天',
                        onClick(picker) {
                            const date = new Date();
                            date.setTime(date.getTime() - 3600 * 1000 * 24);
                            picker.$emit('pick', date);
                        }
                    }, {
                        text: '一周前',
                        onClick(picker) {
                            const date = new Date();
                            date.setTime(date.getTime() - 3600 * 1000 * 24 * 7);
                            picker.$emit('pick', date);
                        }
                    }]
                },

                
                // 定义输入规则
                rules: {
                    name: [
                            // 指定验证函数             触发时机。这个是失去焦点触发
                        {validator: validatName, trigger: 'blur'}
                    ],
                },
            };
        },

        methods: {
            onOk() {
                
                // 使用ref进行验证 validate传入一个函数 返回一个验证是否成功的bool值
                this.$refs['ruleForm'].validate((valid) => {
                    if (valid) {

                        const {
                            name,
                            dates
                        } = this.form;

                    // 避免zip重复 zip++
                        const maxZip = Math.max(...this.tableData.map(item => item.zip)) + 1;

                        const obj = {
                            name,
                            date: dates,
                            province: '北京',
                            city: '普陀区',
                            address: '上海市普陀区金沙江路 1518 弄',
                            zip: maxZip
                        };

                // push到数据里面
                        this.tableData.push(obj);

                // 将模态隐藏
                        this.dialogFormVisible = false;
                    } else {
                        return false;
                    }
                });
            },

            // 删除数据
            handleDelete(row) {
                this.tableData.map((item, index) => {
                    if (item.zip === row.zip) {
                        this.tableData.splice(index, 1);
                    }
                });
            },

            handleCreate() {
                // 模态展示
                this.dialogFormVisible = true;
            }
        }
    };
</script>

一套基本的增删改查就可以了呀,Vue有一套admin模版,开箱即用。 vue-element-admin非常不错,大家可以去使用一下子

打包

默认打包的话会导致静态资源引用存在问题,打开一片空白,所以我们打包前需要先配置一下静态资源 在package.json这个文件同级的目录,新建一个vue.config.js,加入如下配置

/**
 *  Created By 憧憬
 */
module.exports = {
    publicPath: './'        // 静态资源目录配置为./ 当前目录
};

本文为作者原创,手码不易,允许转载,转载后请以链接形式说明文章出处。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • SpringBoot 自定义banner (小彩蛋)

    我在使用其他人的jar包的时候, 发现启动图像有点东西, 所以自己弄了一下。各位看官有兴趣也弄一下

    憧憬博客
  • 字符串匹配 - KMP算法

    实现 strStr() 函数。给定一个 haystack 字符串和一个 needle 字符串,在 haystack 字符串中找出 needle 字符串出现的第一...

    憧憬博客
  • cAdvisor + Prometheus收集本机和docker容器数据

    在这个万物结可容器化的时代,监控显的尤为重要,在本篇文章,我们将对服务器的相关容器和本机数据利用 Cadvisor 进行收集,通过 Prometheus 作为数...

    憧憬博客
  • 浅入深出Vue:注册

    基本布局已经有了, 现在我们来开始做我们的注册页面~ 当然需要注册才能发表文章啊(糟老头子坏得很, 我可以只有我一个人能发啊)。

    若羽
  • SaaS-HRM企业管理

    在src目录下创建文件夹,命名规则:module-模块名称()在文件夹下按照指定的结构配置assets,components,pages,router,stor...

    cwl_java
  • jQuery 写法示例

    Joel
  • DOM 操作写法示例

    Joel
  • 【Vue.js】Vue.js组件库Element的基础用法

    Element是一套为开发者、设计师和产品经理准备的基于 Vue 2.0 的桌面端组件库,是帮助网站快速成型的工具。

    魏晓蕾
  • 自定义element UI的upload组件

    本文由腾讯云+社区自动同步,原文地址 https://stackoverflow.club/article/elementui_upload_custom/

    羽翰尘
  • 【Vue.js】Vue.js组件库Element中的图片、回到顶部、无限滚动和抽屉

    在要实现滚动加载的列表上上添加v-infinite-scroll,并赋值相应的加载方法,可实现滚动到底部时自动执行加载方法。

    魏晓蕾

扫码关注云+社区

领取腾讯云代金券