打通前后端全栈开发node+vue进阶课程学习系统项目实战详细讲解:用户添加/修改/删除 vue表格组件 vue分页组件

Posted 成都苏天天

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了打通前后端全栈开发node+vue进阶课程学习系统项目实战详细讲解:用户添加/修改/删除 vue表格组件 vue分页组件相关的知识,希望对你有一定的参考价值。

第三章 建议学习时间8小时      总项目预计10章

 

学习方式:详细阅读,并手动实现相关代码(如果没有node和vue基础,请学习前面的vue和node基础博客【共10章】

演示地址:后台:demoback.lalalaweb.com  前台:demo.lalalaweb.com

演示过程中可能会发现bug,希望即时留言反馈,谢谢

源码下载:https://github.com/sutianbinde/classweb               //不是全部的代码,每次更新博客才更新代码

学习目标:此教程将教会大家 如何一步一步实现一个完整的课程学习系统(包括课程管理后台/Node服务器/学习门户三个模块)。

上次node基础课程博客大家反响很好,时隔3个月,才更新项目部分,预计2~3天更新一章,我尽量20天更新完毕,学完这个项目Nodejs和vue就基本熟悉了,如发现教程有误的地方,请及时留言反馈

视频教程地址:www.lalalaweb.com,后期会上传教学视频,大家可前往视频学习(暂时还没有视频)

 

用户添加/修改/删除  表格组件  分页组件


 首先我们通过命令行启动前面已经写完的项目

 

由于要用到表格,我们这里就得封装 表格和分页组件

 先在componets中创建分页组件 pagebar.vue,写入以下代码(功能是传入分页信息,然后展示分页,点击分页的时候,会向上触发goto()跳转到第几页,具体参数的解释在代码中,对于组件不熟悉的,可以再去看看前面的基础教程)

<template>
        <ul class="pagination">
            <li :class="{hideLi:current == 1}" @click="goto(current-1)">
                <a href="javascript:;" aria-label="Previous">
                    <span aria-hidden="true">&laquo;</span>
                </a>
            </li>
            <li v-for="index in pages" @click="goto(index)" :class="{\'active\':current == index}" :key="index">
              <a href="javascript:;" >{{index}}</a>
            </li>
            <!--<li><a href="javascript:;">10</a></li>-->
            <li :class="{hideLi:(allpage == current || allpage == 0)}" @click="goto(current+1)">
                <a href="javascript:;" aria-label="Next">
                    <span aria-hidden="true">&raquo;</span>
                </a>
            </li>
       </ul>
       
</template>

<script>
    /*
     分页组件
     设置props
         current 当前页    默认1
         showItem 显示几页    默认5
         allpage    共多少页     10
     
    **/
    export default {
        name: \'page\',
        data () {
            return {}
        },
        props:{
            current:{
                type:Number,
                default:1
            },
            showItem:{
                type:Number,
                default:5
            },
            allpage:{
                type:Number,
                default:10
            }
        },
        computed:{
            pages:function(){
                var pag = [];
                   if( this.current < this.showItem ){ //如果当前的激活的项 小于要显示的条数
                        //总页数和要显示的条数那个大就显示多少条
                        var i = Math.min(this.showItem,this.allpage);
                        while(i){
                            pag.unshift(i--);
                        }
                    }else{ //当前页数大于显示页数了
                        var middle = this.current - Math.floor(this.showItem / 2 ),//从哪里开始
                            i = this.showItem;
                        if( middle >  (this.allpage - this.showItem)  ){
                            middle = (this.allpage - this.showItem) + 1
                        }
                        while(i--){
                            pag.push( middle++ );
                        }
                    }
                return pag
            }
        },
        methods:{
            /*editHandler(item){
                this.$emit("on-edit",item);
            }*/
            goto:function(index){
                if(index == this.current) return;
                    //this.current = index;
                    //这里可以发送ajax请求
                    this.$emit("on-gopage",index);
            }
        }
    }
</script>

<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
/*分页*/
    .pagination{
        margin: 10px;
        display: inline-block;
    }
    .pagination >li{
        display: inline;
    }
    .pagination>li>a, .pagination>li>span{
        float: left;
        padding: 6px 12px;
        margin-left: -1px;
        line-height: 1.42857143;
        color: #4187db;
        text-decoration: none;
        background-color: #fff;
        border: 1px solid #f8f9fb;
    }

    .pagination>li>a:hover{
        background-color: #f8f9fb;
    }
    .pagination>.active>a{
        background-color: #4187db !important;
        color: #fff;
    }
    .hideLi a{
        visibility: hidden;
    }
</style>

 

然后在componets中创建 grid.vue ,表格组件,然后写入以下代码,我们在表格组件中,引入了分页组件,这样就不用在主页面中两次引入了,参数的注释在代码中,这里我们需要传入表格数据的头信息和列表信息

<template>
    <div class="">
        
        <table border="" cellspacing="" cellpadding="">
            <thead>
                <tr><th>序号</th>
                    <th v-for="(item, index) in theadData">{{item.title}}</th>
                </tr>
            </thead>
            <tbody>
                <tr v-if="!listData.length">
                    <td>1</td><td>没有数据 . . .</td>
                    <td v-for="(item, index) in theadData" v-if="index<=theadData.length-2"></td>
                </tr>
                <tr v-for="(item, index) in listData">
                    <td>{{index+1}}</td>
                    <!--按照头部的-->
                    <td  v-for="(item2, index2) in theadData">
                        <span v-if="index2 === 0" style="float: right;">
                            <i title="编辑" v-if="ifEdit" class="fa fa-edit" aria-hidden="true" @click="editHandler(item)"></i>
                            <i title="删除" v-if="ifDelete" class="fa fa-trash" aria-hidden="true" @click="deleteHandler(item)"></i>
                            <i title="下移" v-if="ifDown" class="fa fa-arrow-circle-o-down" aria-hidden="true" @click="downHandler(item)"></i>
                            <i title="上移" v-if="ifUp" class="fa fa-arrow-circle-o-up" aria-hidden="true" @click="upHandler(item)"></i>
                            <i title="封号"v-if="ifReset" class="fa fa-unlock-alt" aria-hidden="true" @click="resetHandler(item)"></i>
                        </span>
                        {{item[item2.keyname]}}
                    </td>
                </tr>
                
            </tbody>
        </table>
        
        <pagebar v-if="ifpage" :current="pageInfo.current" :showItem="pageInfo.showItem" :allpage="pageInfo.allpage" @on-gopage="gopage"></pagebar>
    </div>
</template>

<script>
    /*
     表格组件
     设置props
         theadData 表头数据    默认[]
         listData 表格数据    默认[]
         ifpage    是否分页     默认true
         ifEdit/ifDelete/ifUp/ifDown    是否可编辑/删除/上下移动  默认false
         
      定制模板
          slot为grid-thead 定制表格头部
          slot为grid-handler 定制表格操作
          
      监听状态变化
          on-delete 删除
          on-edit   编辑
          on-up     上移
          on-down   下移
          
      分页
      pageInfo 分页信息如下  默认{}   --  或者单独使用 pagebar.vue
      {
          current:当前第几页     1
          showItem:显示多少页 5
          allpage:共多少页        10
      }
     
    **/
    
    import pagebar from \'./pagebar.vue\'
    export default {
        name: \'grid\',
        data () {
            return {
    
            }
        },
        props:{
            listData:{
                type:Array,
                default:function(){
                    return [{
                        name:"没有数据 . . ."
                    }]
                }
            },
            theadData:{
                type:Array,
                default:function(){
                    return [{
                        title:"名字",
                        keyname:"name"
                    }]
                }
            },
            ifpage:{
                type:Boolean,
                default:true
            },
            ifEdit:{
                type:Boolean,
                default:false
            },
            ifDelete:{
                type:Boolean,
                default:false
            },
            ifUp:{
                type:Boolean,
                default:false
            },
            ifDown:{
                type:Boolean,
                default:false
            },
            ifReset:{
                type:Boolean,
                default:false
            },
            pageInfo:{
                type:Object,
                default:function(){
                    return {}
                }
            }
        },
        methods:{
            editHandler(item){
                this.$emit("on-edit",item);
            },
            deleteHandler(item){
                this.$emit("on-delete",item);
            },
            downHandler(item){
                this.$emit("on-down",item);
            },
            upHandler(item){
                this.$emit("on-up",item);
            },
            resetHandler(item){
                this.$emit("on-reset",item);
            },
            gopage(index){
                this.$emit("on-gopage",index);
            }
        },
        components:{pagebar}
    }
</script>

<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>

    table{
        border: none 0;
        border-collapse: collapse;
        color: #51555a;
        width: 100%;
        border-bottom: 1px solid #DFE3EA;
    }
    td, th{
        padding: 10px 20px;
        text-align: left;
        border-width:0;
    }
    thead tr, tr:nth-of-type(even){
        background: #f8f9fb;
    }
    /*tbody tr:hover{
        background: #f4f6fb;
    }*/
    td .fa{
        padding:0 5px;
        cursor: pointer;
        opacity: 0;
        transition: all 0.3s ease;
    }
    td .fa:first-child{
        margin-left: 10px;
    }
    tr:hover .fa{
        opacity: 1;
    }
    td .fa:hover{
        color: #4187db;
        transform: scale(1.2);
    }
    
    
</style>

表格头信息和列表数据 需要传入的数据格式 如下(这只是展示,帮助大家理解上面的代码的,不用写到页面中)

    var listData = [
        {
            name:"css+html基础",
            duration:"30h",
            teacher:"小豆子",
            videoNb:"20",
            sysId:1
        },{
            name:"javascript进阶",
            duration:"20h",
            teacher:"小豆子",
            videoNb:"12",
            sysId:2
        },{
            name:"移动端全解析 ",
            duration:"10h",
            teacher:"小豆子",
            videoNb:"3",
            sysId:3
        },{
            name:"10分钟系列 ",
            duration:"23h",
            teacher:"小豆子",
            videoNb:"2",
            sysId:4
        },{
            name:"移动端动态网页编程",
            duration:"10h",
            teacher:"小豆子",
            videoNb:"10",
            sysId:5
        }
    ];
    var theadData = [
        {
            title:"课程名称",
            keyname:"name"
        },{
            title:"时长",
            keyname:"duration"
        },{
            title:"视频数量",
            keyname:"videoNb"
        },{
            title:"老师",
            keyname:"teacher"
        }
    ];

 

然后我们修改系统管理员列表组件(我们上一章中建立的 adminList.vue),修改其中的代码如下,我们这里代码比较多,包括了增删该,分页等功能,确实不好分步骤讲解,这里就直接上代码了,整体来说,方法都很明确,希望大家能看懂,中间的ajax接口我们下一步再去Node端写。

注:这里我们没有对输入数据进行严格的正则验证,是因为此后台功能设定为内部人员使用,所以不需要像前台用户注册页面那样写非常复杂的验证

<template>
  

以上是关于打通前后端全栈开发node+vue进阶课程学习系统项目实战详细讲解:用户添加/修改/删除 vue表格组件 vue分页组件的主要内容,如果未能解决你的问题,请参考以下文章

Nodejs系列课程,从入门到进阶帮你打通全栈

前端学完vue学啥

一本涵盖Web前后端全栈开发的JavaScript入门教程

Vue.js+Node.js全栈开发入门实战 | 推荐

进阶 vue 全家桶

基于NodeJS+Express+mongoDB+Bootstrap的全栈式工程化开发前后端分离博客系统实战