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>