项目框架
Element-ui+Vue+jQuery+Bootstrap+Echarts。
嵌入vue使用的是<script>,没有使用vue-cli,请自行将<template>内代码贴入html,<style>内代码贴入样式表。
checkbox全选和全不选
<template> <el-form-item label="地电阻率选项:"> <el-checkbox class="search_item" v-model="eidAll" @change="handleEidAllChange">全选</el-checkbox> <el-checkbox-group v-model="searchItem.eid"> <el-checkbox class="search_item" v-for="item of eidList" :label="item.value">{{ item.name }}</el-checkbox> </el-checkbox-group> </el-form-item> </template> <script> var app = new Vue({ el: '#app', data: { // 全选变量 eidAll: false // checkbox单项 searchItem: { eid: [], }, // checkbox数据循环 eidList: [{ name: '缺数', value: 'DZ1' // ... }] }, methods: { // 处理全选 handleEidAllChange() { if (this.eidAll) { this.searchItem.eid = []; var arr = []; for (let i in this.eidList) { arr.push(this.eidList[i].value); } this.searchItem.eid = arr; } else { this.searchItem.eid = []; } }, }, watch: { // 监听checkbox是否全部选择 "searchItem.eid": function() { if (this.searchItem.eid.length == this.eidList.length) { this.eidAll = true } else { this.eidAll = false } } } }); </script>
表头固定,表身滚动
方案①:el-table,卡死,据说和vue版本有关系,但是升级了仍然卡死,抛弃。
方案②:table,要设置display:table; table-layout: fixed;,布局有局限性。
方案③:div+el-col模拟table。
<template> <div class="table"> <div class="thead"> <div class="tr"> <el-row> <el-col v-for="item of tableHeadList" :span="item.col"> <div class="th"> {{ item.text }} </div> </el-col> </el-row> </div> </div> <div class="tbody"> <div class="tr" v-for="(item, index) of tableData"> <el-row> <el-col v-for="bodyItem of tableBodyList" :span="bodyItem.col"> <div class="td"> {{ item[bodyItem.field] }} </div> </el-col> </el-row> </div> </div> </div> </template> <style> .table .tbody { width: 100%; height: 278px; overflow-y: scroll; } </style> <script> var app = new Vue({ el: '#app', data: { // th数据循环 tableHeadList: [{ // 根据type来v-if th的标题内容,根据需求放文本或checkbox type: 'text', // 每格占用栅格,element-ui总栅格数是24 col: '1', // th标题 text: 'ID' }], // td数据循环 tableBodyList: [{ type: 'text', col: '1', // 接口返回字段 field: 'id' }], // 表格数据 tableData: [...] } }); </script>
表格滚动无限加载
可以用插件,但为了轻量就自己写吧,此处用jQuery。
<script> var app = new Vue({ el: '#app', mounted: function() { // 监听滚动 this.handleScrollLoad(); }, data: { // 加载完全部数据,更换查询条件时请先初始化为false loadAll: false, // 页码,更换查询条件时请先初始化为1 offset: 1, // 表格数据,更换查询条件时请先清空 tableData: [] }, methods: { // 处理滚动加载 handleScrollLoad() { var $this = this var nScrollHight = 0; var nScrollTop = 0; var nDivHight = $(".table .tbody").height(); $(".table .tbody").scroll(function() { if ($this.loadAll) { // 全部加载完不进行操作 return; } nScrollHight = $(this)[0].scrollHeight; nScrollTop = $(this)[0].scrollTop; if (nScrollTop + nDivHight >= nScrollHight) { // 滑到底部,offset递增 // 因为我们后端定义的offset其实是page,代表第几页,而不是真正意义上的offset // 有需要的人可以转为$this.offset += $this.limit; $this.offset += 1; $this.searchData() } }); }, // 查询表格数据 searchData() { ... var $this = this axios.get(str) .then(res => { if (res.status === 200) { // 请求正常,判断是否加载完全部 if (res.data.rows.length === 0) { $this.loadAll = true; return; } for (let i of res.data.rows) { $this.tableData.push(i); } } else { // 请求错误 alert('请求错误,错误码:' + res.status); } }, e => { this.loading = false; throw new Error('请求失败:' + e); }) } } }); </script>
多个echarts
既然使用了vue,嵌入echarts最好的方式当然是组件,将echarts封装成组件,再通过v-for循环,每次数据更新再setOption。
<template> <div class="echarts_box"> <charts v-for="(item, index) of echartsData" :item="item"></charts> </div> </template> <script> var app = new Vue({ el: '#app', data: { // 曲线数据 echartsData: [] } }); /*****************************曲线实例****************************/ Vue.component('charts', { props: { item: Object }, methods: { // 初始化曲线 initChart() { this['echart' + (this.item.id)] = echarts.init(document.getElementById('echart' + this.item.id)); this.setChart(); }, setChart() { var $this = this let option = { ... }; this['echart' + this.item.id].setOption(option); } }, mounted() { this.initChart(); }, watch: { item: { handler: function () { this.setChart(); }, deep: true } }, template: `<div class="echart_item" :id="'echart'+item.id" style="height:260px;"></div>` }); </script>
后记
使用这个框架做项目断断续续也做了很久了,一直都没有特意去总结,导致每次都要翻从前的代码,回忆良久,例如el-checkbox,不同于其他表单项,它的label才是真正的value,每次都要重新查阅文档+回忆,其实是很费时的。
总结项目套路是很有必要的,我觉得随着工作时间增长,一个人是进步,还是重复工作,和会不会总结有本质联系。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]