<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        使用Bootstrap + Vue.js實現表格的動態展示、新增和刪除功能

        來源:懂視網 責編:小采 時間:2020-11-27 22:25:03
        文檔

        使用Bootstrap + Vue.js實現表格的動態展示、新增和刪除功能

        使用Bootstrap + Vue.js實現表格的動態展示、新增和刪除功能:一、寫在前面 1. Bootstrap是一個由 Twitter 開發和維護的前端框架,目前很受歡迎,Bootstrap中文網點擊這里。 2. Vue.js 是一套構建用戶界面的漸進式框架,點這里訪問官網。 二、實現效果: 三、頁面引入bootstrap、vue資源 <link
        推薦度:
        導讀使用Bootstrap + Vue.js實現表格的動態展示、新增和刪除功能:一、寫在前面 1. Bootstrap是一個由 Twitter 開發和維護的前端框架,目前很受歡迎,Bootstrap中文網點擊這里。 2. Vue.js 是一套構建用戶界面的漸進式框架,點這里訪問官網。 二、實現效果: 三、頁面引入bootstrap、vue資源 <link

        一、寫在前面

        1. Bootstrap是一個由 Twitter 開發和維護的前端框架,目前很受歡迎,Bootstrap中文網點擊這里。

        2. Vue.js 是一套構建用戶界面的漸進式框架,點這里訪問官網。

        二、實現效果:

        三、頁面引入bootstrap、vue資源

        <link rel="stylesheet"  rel="external nofollow" >
        <link rel="stylesheet"  rel="external nofollow" >
        <script src="https://www.gxlcms.com//cdn.bootcss.com/jquery/3.2.1/jquery.min.js"></script>
        <script src="https://www.gxlcms.com//cdn.bootcss.com/popper.js/1.12.5/umd/popper.min.js"></script>
        <script src="https://www.gxlcms.com//cdn.bootcss.com/bootstrap/4.0.0-beta/js/bootstrap.min.js"></script>
        <script src="https://www.gxlcms.com//cdn.bootcss.com/vue/2.5.8/vue.min.js"></script>

        這里需要注意的是,Boostrap依賴于JQuery,必須在引入Boostrap之前引入JQuery。

        四、繪制表格

        1.工具欄區

        <div class="row mx-auto w-75">
         <div class="col-6">
         <div class="btn-group">
         <button type="button" class="btn btn-outline-info btn-sm" data-toggle="modal" data-target="#myModal">新增</button>
         <button type="button" class="btn btn-outline-primary btn-sm" @click="saveRows">保存</button>
         </div>
         <button type="button" class="btn btn-outline-warning btn-sm" @click="delRows">刪除</button>
         </div>
         <div class="col-6">
         <div class="input-group">
         <input type="text" class="form-control input-group-sm" placeholder="輸入設備編號進行搜索">
         <span class="input-group-btn">
         <button class="btn btn-default" type="button"><i class="fa fa-search"></i></button>
         </span>
         </div>
         </div>
         </div>

        2.表格區

        <div class="row mx-auto w-75">
         <div class="col-12">
         <table class="table table-hover table-success">
         <thead class="thead-default">
         <tr>
         <th><input type="checkbox"></th>
         <th>序號</th>
         <th>設備編號</th>
         <th>設備名稱</th>
         <th>設備狀態</th>
         <th>采購日期</th>
         <th>設備管理員</th>
         </tr>
         </thead>
         <tbody>
         <tr v-for="(facility,index) in facilities">
         <td><input type="checkbox" :value="index" v-model="checkedRows"></td>
         <td>{{index+1}}</td>
         <td>{{facility.code}}</td>
         <td>{{facility.name}}</td>
         <td>{{facility.states}}</td>
         <td>{{facility.date}}</td>
         <td>{{facility.admin}}</td>
         </tr>
         </tbody>
         </table>
         </div>
         </div>

        這里需要說明的是:

        1.表格table的class Bootstrap3和Boostrap4有所不同;

        2. vue.js for循環,vue1與vue2有所出入,尤其是下標index的使用。

        以上兩點我們在使用中需要根據自己的版本做相應調整了。

        至此,展示表格數據的靜態頁面已經完成,接下來我們使用Vue.js使表格數據成為動態的。

        五、 創建VUE對象、初始化表格數據

        1.初始化數據

        var datas = [
         {
         code: "A2017-001",
         name: "3800充電器",
         states: "正常",
         date: "2017-01-21",
         admin: "andy"
         },
         {
         code: "A2017-002",
         name: "Lenovo Type-c轉接器",
         states: "正常",
         date: "2017-01-21",
         admin: "zero"
         }];

        Tips: datas在實際的場景中應當是通過ajax的方式訪問后臺獲取的業務數據。

        2.創建vue對象

        new Vue({
         el: "#vueApp",
         data: {
         checkAll: false,// 是否全選
         checkedRows: [],// 選中的行標,用于刪除行
         facilities: datas,// 表格數據
         newRow:{}// 新增的行數據,用于新增行
         }
         })

        ok,我們已經完成了表格數據的動態展示,下面我們來實現刪除行數據功能。

        六、刪除行

        刪除按鈕:

        <button type="button" class="btn btn-outline-warning btn-sm" @click="delRows">刪除</button>

        實現刪除功能:

        delRows:function () {
         if (this.checkedRows.length <= 0){//是否選中判斷
         alert("您未選擇需要刪除的數據");
         return false;
         }
         if (!confirm("您確定要刪除選擇的數據嗎?")){//刪除確認
         return false;
         }
        
         for(var i=0;i<this.checkedRows.length;i++){//循環獲取選中的行標
         var checkedRowIndex = this.checkedRows[i];
         /**根據下標移除數組元素*/
         this.facilities = $.grep(this.facilities,function (facility,j) {
         return j != checkedRowIndex;
         });
         }
         this.checkedRows = [];//清空選中行數據
         }

        實現效果:

        七、新增行

        1.新增按鈕

        <button type="button" class="btn btn-outline-info btn-sm" data-toggle="modal" data-target="#myModal">新增</button>

        2.添加模態框用于錄入新增數據

        <div class="modal fade" id="myModal">
         <div class="modal-dialog">
         <div class="modal-content">
         <div class="modal-header">
         <h4 class="modal-title">新增設備信息</h4>
         <button type="button" class="close" data-dismiss="modal">×</button>
         </div>
         <div class="modal-body">
         <div class="row">
         <div class="col-3">設備編號:</div>
         <div class="col-9">
         <input class="form-control" placeholder="設備編號" v-model="newRow.code">
         </div>
         </div>
         <div class="row">
         <div class="col-3">設備名稱:</div>
         <div class="col-9">
         <input class="form-control" placeholder="設備名稱" v-model="newRow.name">
         </div>
         </div>
         <div class="row">
         <div class="col-3">設備狀態:</div>
         <div class="col-9">
         <input class="form-control" placeholder="設備狀態" v-model="newRow.states">
         </div>
         </div>
         <div class="row">
         <div class="col-3">采購日期:</div>
         <div class="col-9">
         <input class="form-control" placeholder="采購日期" v-model="newRow.date">
         </div>
         </div>
         <div class="row">
         <div class="col-3">管理員:</div>
         <div class="col-9">
         <input class="form-control" placeholder="管理員" v-model="newRow.admin">
         </div>
         </div>
         </div>
         <div class="modal-footer">
         <button type="button" class="btn btn-outline-primary" data-dismiss="modal" @click="addRow">確認</button>
         </div>
         </div>
         </div>
         </div>

        3.實現新增邏輯

        addRow: function () {
         this.facilities.push(this.newRow);//新行數據追加至表格數據數組中
         this.newRow = {};//新行數據置空
         }

        好了,動態展示、新增和刪除功能就講完了,后邊有空我們再來討論頁面上未實現的全選、快速檢索等功能。

        附1:完整js

        <script>
         var datas = [
         {
         code: "A2017-001",
         name: "3800充電器",
         states: "正常",
         date: "2017-01-21",
         admin: "andy"
         },
         {
         code: "A2017-002",
         name: "Lenovo Type-c轉接器",
         states: "正常",
         date: "2017-01-21",
         admin: "zero"
         }];
         new Vue({
         el: "#vueApp",
         data: {
         checkAll: false,
         checkedRows: [],
         facilities: datas,
         newRow:{}
         },
         methods: {
         addRow: function () {
         this.facilities.push(this.newRow);
         this.newRow = {};
         },
         saveRows:function () {//保存表格數據
         },
         delRows:function () {
         if (this.checkedRows.length <= 0){
         alert("您未選擇需要刪除的數據");
         return false;
         }
         if (!confirm("您確定要刪除選擇的數據嗎?")){
         return false;
         }
         for(var i=0;i<this.checkedRows.length;i++){
         var checkedRowIndex = this.checkedRows[i];
         this.facilities = $.grep(this.facilities,function (facility,j) {
         return j != checkedRowIndex;
         });
         }
         this.checkedRows = [];
         }
         }
         });
        </script>

        頁面源碼已共享至GitHub, 點擊這里 可查看下載,歡迎探討。

        總結

        以上所述是小編給大家介紹的使用Bootstrap + Vue.js實現表格的動態展示、新增和刪除功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        使用Bootstrap + Vue.js實現表格的動態展示、新增和刪除功能

        使用Bootstrap + Vue.js實現表格的動態展示、新增和刪除功能:一、寫在前面 1. Bootstrap是一個由 Twitter 開發和維護的前端框架,目前很受歡迎,Bootstrap中文網點擊這里。 2. Vue.js 是一套構建用戶界面的漸進式框架,點這里訪問官網。 二、實現效果: 三、頁面引入bootstrap、vue資源 <link
        推薦度:
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 最近更新免费中文字幕大全 | 久久精品网站免费观看| 91精品国产免费久久国语麻豆| 国产成人精品久久免费动漫| 免费亚洲视频在线观看| 亚洲无码精品浪潮| 久久青青草原亚洲av无码app| 午夜在线a亚洲v天堂网2019| 成人午夜免费视频| 91人人区免费区人人| 亚洲视频在线不卡| 一级一片免费视频播放| 久久精品免费一区二区| 蜜桃AV无码免费看永久| 国产成人精品亚洲精品| 国产一级a毛一级a看免费人娇| 亚洲欧洲免费无码| 亚洲国产精品久久久久网站| 国产成人综合亚洲| 国产精品久久久久免费a∨| 亚洲区日韩精品中文字幕| 久久午夜夜伦鲁鲁片免费无码| 国产成人无码a区在线观看视频免费| 色播亚洲视频在线观看| 免费看黄视频网站| 亚洲美女视频一区二区三区| 免费无码肉片在线观看| 免费一区二区三区在线视频| 性感美女视频免费网站午夜| 7777久久亚洲中文字幕蜜桃| 成年女人毛片免费播放视频m| 91亚洲精品视频| 全免费a级毛片免费看无码| 欧洲 亚洲 国产图片综合| 亚洲高清无码在线观看| 亚洲人成网站18禁止| 中文字幕精品无码亚洲字| 国产亚洲日韩在线a不卡| 久久国产精品亚洲综合| 免费成人在线电影| 亚洲AV永久无码精品成人|