bootstrap的简单使用,离线存储,Vue中表单输入,动态样式之class,常用的事件修饰符与键盘修饰符

Bootstrap

官网地址

https://www.bootcss.com/

https://v4.bootcss.com/ (4版本的官网)

概念

简洁、直观、强悍的前端开发框架,让web开发更迅速、简单。
一套简单的UI框架

下载方式

一、cdn

<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@4.5.0/dist/css/bootstrap.min.css">

二、通过npm去下载

npm install bootstrap     (这个命令是下载npm上最新的版本)
npm install(i) bootstrap@3 (@3 指定下载3版本)

学员信息表管理小案例:
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        [v-cloak]{
            display: none;
        }
    </style>
    <link rel="stylesheet" href="./node_modules/bootstrap/dist/css/bootstrap.min.css">
    <script src="./node_modules/vue/dist/vue.js"></script>
</head>
  <!--
       当页面疯狂刷新,出现闪屏如何解决? 
       解决方法两种: 一、利用v-text,本身没有 {{}} , 那么就不会出现相关问题。
                   二、全局解决刷新闪频问题,指令v-cloak
      -->
    <div id="app"  v-cloak>
        <!--  利用bootstrap创建一个container -->
        <div class="container">
            <h2 class="text-center text-primary">学员信息输入</h2>
            <form>
                <div class="form-group">
                    <label for="name">姓名</label>
                    <input type="email" class="form-control" id="name" aria-describedby="emailHelp"
                        v-model='userInfo.name'>
                </div>
                <div class="form-group">
                    <label for="age">年龄</label>
                    <input type="text" class="form-control" id="age" v-model='userInfo.age'>
                </div>
                <div class="form-group">
                    <label for="tel">手机号</label>
                    <input type="text" class="form-control" id="tel" v-model='userInfo.tel'>
                </div>
                <div class="form-group">
                    <label for="remark">备注信息</label>
                    <textarea id="reamrk" cols="100" rows="2" v-model='userInfo.remark'></textarea>
                </div>
                <div class="text-center"><button type="button" class="btn btn-primary" @click='add'>添加</button>
                    <button type="button" class="btn btn-info" @click='reset'>重置</button></div>
            </form>
            <h2 class="text-center text-primary">学员信息表</h2>
            <table class="table table-bordered table-hover">
                <thead>
                    <tr>
                        <th scope="col">序号</th>
                        <th scope="col">姓名</th>
                        <th scope="col">年龄</th>
                        <th scope="col">手机号</th>
                        <th scope="col">备注信息</th>
                        <th>操作</th>
                    </tr>
                </thead>
                <tbody>
                    <tr v-for='(item,index) in uInfo'>
                        <td>{{ index>8 ? index+1 : '0' + (index+1)}} </td>
                        <td>{{item.name}} </td>
                        <td>{{item.age}}</td>
                        <td>{{item.tel}}</td>
                        <td>{{item.remark}}</td>
                        <td>
                            <button type="button" class="btn btn-danger" @click='del(index)'>删除</button>
                        </td>
                    </tr>
                   <tr>
                        <!-- v-if 和 v-else必须连着使用,否则不生效会报错 -->
                       <td colspan="6" v-if='!uInfo.length'>暂无数据</td>
                       <td colspan="6" v-else><button type="button" class="btn btn-danger" @click='delAll'>全部删除</button></td>
                   </tr>

                </tbody>
            </table>
        </div>
    </div>
 <script>
        new Vue({
            el: '#app',
            data: {
                userInfo: {
                    name: '',
                    age: '',
                    tel: '',
                    remark: ''
                },
                uInfo: localStorage.getItem('uInfo') ? JSON.parse(localStorage.getItem('uInfo')): []
            },
            methods: {
                // 添加
                add() {
                    if(!this.userInfo.name || !this.userInfo.age || !this.userInfo.tel || !this.userInfo.remark){
                        alert('输入信息不能为空');
                        return;
                    };
                    this.uInfo.push(this.userInfo);
                    this.reset();
                    localStorage.setItem('uInfo',JSON.stringify(this.uInfo));
                },
                // 重置
                reset() {
                    this.userInfo = {
                        name: '',
                        age: '',
                        tel: '',
                        remark: ''
                    }
                },
                // 单删
                del(index) {
                    this.uInfo.splice(index,1);   
                    localStorage.setItem('uInfo',JSON.stringify(this.uInfo));  
                },
                // 全删
                delAll(){
                    this.uInfo = [];
                    localStorage.setItem('uInfo',JSON.stringify(this.uInfo));
                }
            }
        })

        
    </script>
    <!-- 学员信息表思路:
                一、利用UI框架搭建静态页
                二、把表格的数据转化成假数据,并循环遍历
                三、书写逻辑交互
                四、刷新页面,数据还在,利用离线存储方法  -->
 

离线存储

概念:离线存储是H5新增的属性,没有出现这个属性之前,我们的存储用cookie。出现之后大部分的存储都被离线存储所代替
离线存储包含两部分:一、本地存储localStorage 二、会话存储sesssionStorage
记忆要点
一、localStorage和sesssionStorage
二、localStorage和sesssionStorage以及cookie的区别
三、离线存储中哪一个方法可以实现跨页面存储(就是localStorage)

离线存储两种方法的区别

相同点:都可以缓存内容,大小都是5M左右,存储形式必须是字符串它们的使用语法都一样
存值: localStorage/sesssionStorage.setItem(key,value)
取值: localStorage/sesssionStorage.getItem(key)
删除某一个值: localStorage/sesssionStorage.removeItem(key)
不同点: localStorage它又名永久存储,只要不删除,永远存储,关闭浏览器不消失
sesssionStorage名会话存储,关闭浏览器即消失

表单输入

单选框  

  <div>
            <!-- 单选框一定要写 value,且value是后端要取的数值 -->
            性别:
            <input type="radio" name='sex' value='0' v-model='regList.sex'><input type="radio" name='sex' value="1" v-model='regList.sex'></div>

复选框

 <div>
            <!-- 
                复选框:定义checkbox初始值,应是一个[] ,获取值的时候,获取的是value 的值 
                你也可以有默认值:eg:['play']
            -->
            <input type="checkbox" value='study' v-model='regList.hobby'>学习
            <input type="checkbox" value='sleep' v-model='regList.hobby'>睡觉
            <input type="checkbox" value='rap' v-model='regList.hobby'>唱歌
            <input type="checkbox" value='play' v-model='regList.hobby'>打篮球
​
        </div>

下拉框       

  <!--下拉框的双向数据绑定,绑定在select标签上。它的value 是option中的value -->
  工作种类: <select v-model='regList.address'>
                <option value="" disabled>--请选择--</option>
                <option value="java">洛阳</option>
                <option value="web">郑州</option>
                <option value="test">北京</option>
                <option value="ui">上海</option>
            </select>

一个checkbox   

  <div>
            <!-- 一个checkbox 复选框,我们初始值可以为空,获取value的时候,是true或者false.我们的初始值也可以是true或者false -->
            协议:<input type="checkbox" v-model='regList.isGree'>
        </div>

动态样式之class

动态class的第一种用法: 设定一个变量 。 例子:    :class='变量属性' 
动态class的第二种用法: eg: :class="[条件?'成立的类名':'不成立的类名']"
动态class的第三种用法: eg: "{'类名A':条件A,'类名B':条件B,'类名C':条件C,'类名D':条件d}...."    
 <style>
        .blue {
            color: blue;
        }

        .red {
            color: red;
        }
        .green{
            color: green;
        }
        .yellow{
            color: yellow;
        }

        .footer{
            width: 100%;
            position: fixed;
            left: 0;
            bottom: 0;
            display: flex;
            background-color: #ccc;
        }
        .footer div{
            flex: 1;
            font: bold 20px/50px '微软雅黑';
        }
        
    </style>

  <div id="app">
        <div>
            <!-- 动态class的第一种用法: 设定一个变量 。 eg:   :class='变量属性' -->
            <p :class="color[0]">{{msg}} </p>
            <button @click='changeCol'>点击我更改颜色</button>

            <ul>
                <!-- 动态class的第二种用法,eg: :class="[条件?'成立的类名':'不成立的类名']" -->
                <li v-for='(item,index) in newsList' :class="[index%2 ? color[0]: color[1]]">{{item.title}} </li>
            </ul>
            
        </div>
        <div class="footer">
            <div v-for='(item,index) in navList' :class='[num==index ? "green": "" ]' @click='change(index)'>{{item.name}} </div>
        </div>

        <!-- 动态class的第三种用法: eg:"{'类名A':条件A,'类名B':条件B,'类名C':条件C,'类名D':条件d}...." -->
        <ul>
            <li v-for='(item,index) in newsList ' :class="{'red': index===3 ,'blue': index===2,'green': index === 1,'yellow': index===0 } ">{{item.title}} </li>
        </ul>
    </div>
  <script>
        new Vue({
            el: '#app',
            data: {
                msg: '花自飘零水自流',
                color: ['blue', 'red'],
                num: 0,
                newsList: [
                    {
                        title: '向世界顶尖科学家论坛作视频致辞'
                    },
                    {
                        title: '让贫困人口和贫困地区同全国一道进入全面小康社会'
                    },
                    {
                        title: '警方跨国解救7名遭绑架中国人 受害者:狗链锁脖 竹签刺指甲'
                    },
                    {
                        title: '以底线思维强化疫情防控 见证中国小康之大美  海报'
                    }
                ],
                navList: [
                    {
                        name: '首页',
                    },
                    {
                        name: '分类',
                    },
                    {
                        name: '购物车',
                    },
                    {
                        name: '个人中心',
                    }
                ]
            },
            methods: {
                changeCol() {
                    this.color = ['green', 'yellow'];
                    // console.log(this.color[0]);
                },
                change(index){
                    // console.log(index);
                    this.num = index;
                }
            }
        })
    </script>
 

常用的事件修饰符

     .prevent   阻止默认事件
      .stop 阻止冒泡事件
      .once 只出现一次
      .self 只触发自己
      .capture 捕获
  <div id="app">
        <div class="menu" @contextmenu.prevent = 'pre'>
            阻止鼠标右键菜单事件即默认事件
        </div>
        <div class="big" @click='big'>
            <div class="small" @click.stop='small'> 阻止冒泡</div>
        </div>
        <div class="big" @click.once='big'>   
            <div class="small" @click='small'> once</div>
        </div>
        <div class="big" @click.self='big'>
            <div class="small" @click='small'>self</div>
        </div>
        <div class="big" @click.capture='big'>
            <div class="small" @click='small'>capture</div>
        </div>
    </div>
  <script>
        new Vue({
            el: '#app',
            data: {
            },
            methods: {
                pre(){
                    console.log('阻止了右键菜单');
                },
                small(){
                    console.log('我是小盒子');
                },
                big(){
                    console.log('我是大盒子');
                }
            }
        })
    </script>
 

常用的键盘修饰符

        .enter     .13
   .shift .16
   .ctrl .17
      .left .37
      .right .39
      .up .38
      .down .40
      .del .46
      .space .32
 <div id="app">
        <input type="text" v-model='msg' @keyup = 'enter1'>
        <hr>
        <input type="text" @keyup.enter= 'enter2' v-model='msg'>
        <input type="text" @keyup.13= 'enter2' v-model='msg'>
    </div>
<script>
        new Vue({
            el:'#app',
            data:{
                msg:''
            },
            methods:{
                enter1(e){
                    console.log(e.keyCode);
                    if(e.keyCode === 13){  // enter键
                        console.log(this.msg);
                    }
                },
                enter2(){
                    console.log(this.msg);
                }
            }
        })
    </script>

  

 

原文地址:https://www.cnblogs.com/cyf666cool/p/13908897.html