tmtTable设计说明文档
文件链接:tmt-table.js
BOSS后台项目用到最多的就是列表页,所以把列表页做成通用组件,可以大大提高开发效率。
因为列表可能有不同的样式,所以在实例化组件时可以传值控制样式,用这种方式:

组件内部接收这个参数对象,判断使用哪套样式,如果不传参,则使用默认的'default'样式。
本组件有3个属性值,分别为:
props: {
//表格的基本参数和设置
options: { required: true, default: {} },
//返回当前点击行的所有原始数据
rowdata: { required: false, default: {} },
//当前的页数
pagination: { required: false, default: 0 }
},
组件的data属性有三个变量:
data() {
return {
//分页总数
pageNum: 0,
//当前页数
currentPage: 0,
//样式加载结束才显示HTML页面,防止样式混乱
isShow: false
}
},
当组件内部代码全部编译完成时,把依赖的bootstrap引入到页面中,并在css加载完毕后显示页面:
ready() {
var __this = this;
//插入依赖的CSS文件
var link = $('<link rel="stylesheet" type="text/css" href="http://h5cdn.wisdomtmt.com/common/util/tmt-table/tmt-table-theme/bootstrap.min.css"/>');
$('head').append(link);
//当CSS加载完成才显示组件
var judgeCssLoad = setInterval(function() {
if (link[0].sheet) {
__this.isShow = true; clearInterval(judgeCssLoad);
}
}, 30)
//处理父组件传入的数据
__this.loadData();
}
组件内部定义了两个方法:
changePage和loadData;
changePage(currentPage) {
//父组件和pagination是双向绑定,所以改变pagination的值,父组件可以接收到
this.$set("pagination", currentPage);
this.currentPage = currentPage;
}
loadData() {
var __this = this;
//判断外部的data数据是否传入,进行分页初始化和绑定事件
var tableData = __this.options.data;
//因为父组件传入的数据有延迟,所以设定200ms的延迟执行
setTimeout(function() {
//拿到父组件传入的数据才执行分页和绑定事件
if (tableData) {
//初始化分页
__this.pageNum = Math.ceil(tableData.total_num / tableData.limit);
//绑定事件,通过jQuery的on方法进行绑定
if (__this.options.fn) {
var fn = __this.options.fn,
keys = Object.keys(fn);
for (let i = 0; i < keys.length; i++) {
var tempArr = keys[i].split(' ');
//先解绑再绑定,防止重复绑定
$(tempArr[0]).unbind();
$(tempArr[0]).on(tempArr[1], function() {
setTimeout(fn[keys[i]], 50);
});
}
}
} else {
//如果没有拿到数据,就再执行一遍
__this.loadData();
}
}, 200); }
组件的watch属性监听了两个变量:
options和pagination:
watch: {
//监听当options发生变化时,重载数据
'options': {
handler: function(val, oldVal) {
this.loadData();
},
deep: true
},
//当前页发生改变时,通知父组件
'pagination': {
handler: function(val, oldVal) {
this.currentPage = val;
}
}
}
最后把tmtTable组件注册到Vue的全局变量上,并在控制台通知组件加载完毕:
Vue.component('tmtTable', tmt_table);
console.log('tmtTable component ready!');

tmtTable设计说明文档的更多相关文章
- PowerDesigner中导出设计说明文档
点击下图的新建按钮,新建一个导出内容的模板 模板设计界面分为2栏,左边是可选的模板内容,右侧是模板,双击左侧条目会添加到右侧,最后生成的文件中就有此项内容. 已经添加到右侧的内容可以编辑,双击右侧的条 ...
- Net 通用权限管理系统源码 带数据库设计文档,部署说明文档
Net 通用权限管理系统源码 带数据库设计文档,部署说明文档 包括数据库设计文档部署安装文档源码数据库文件 下载地址:http://www.mallhd.com/archives/1389
- SWFUpload 2.5.0版 官方说明文档 中文翻译版
原文地址:http://www.cnblogs.com/youring2/archive/2012/07/13/2590010.html#setFileUploadLimit SWFUpload v2 ...
- ICE中间件说明文档
ICE中间件说明文档 1 ICE中间件简介 2 平台核心功能 2.1 接口描述语言(Slice) 2.2 ICE运行时 2.2.1 ...
- Eclipse用法和技巧四:生成说明文档1
写代码经常要添加注释的,java代码的注释也可以分为两种.单行注释以“//”作为开头就可以.段落注释在第一行开头添加“/*”,在最后一行结尾添加“*/"即可.这里介绍一种添加注释的方法,其注 ...
- vnpy官网说明文档网址
接触VNPY一年多,一直对作者设计原理和思想有所困惑.发一篇vnpy官网的说明文档,便于以后理解项目代码. http://www.vnpy.org/archives.html
- 为ASP.NET WEB API生成人性化说明文档
一.为什么要生成说明文档 我们大家都知道,自己写的API要供他人调用,就需要用文字的方式将调用方法和注意事项等写成一个文档以更好的展示我们设计时的想法和思路,便于调用者更加高效的使用我们的API. 当 ...
- INSPIRED启示录 读书笔记 - 第18章 重新定义产品说明文档
理想的产品说明文档 1.产品说明文档应该完整地描述用户体验——不只是用户需求,还包括交互设计和视觉设计.用户需求和用户体验是密不可分的 2.产品说明文档必须准确地描述软件的行为 3.产品说明文档必须以 ...
- ES SQL使用说明文档
ES SQL使用说明文档 一.Elasticsearch术语介绍 l 接近实时(NRT): Elasticsearch 是一个接近实时的搜索平台.这意味着,从索引一个文档直到这个文档能够被搜索到有一 ...
随机推荐
- 一个在ASP.NET中利用服务器控件GridView实现数据增删改查的例子
备注:这是我辅导的一个项目开发组的一个例子,用文章的方式分享出来,给更多的朋友参考.其实我们这几年的项目中,都不怎么使用服务器控件的形式了,而是更多的采用MVC这种开发模式.但是,如果项目的历史背景是 ...
- 精选12个时尚的 CSS3 效果【附源码下载】
这里是精选的12个很炫的 CSS3 效果.CSS3 是对 CSS 规范的一个很大的改善和增强,它使得 Web 开发人员可以很容易的在网站中加入时尚的效果.以前很多需要编写复杂的 JavaScript ...
- Flexbox制作CSS布局实现水平垂直居中
Flexbox实现一个div元素在body页面中水平垂直居中: <!DOCTYPE html><html lang="en"><head> & ...
- html/css基础篇——html代码编写过程中的几个警惕点
本文想说的警惕点与浏览器兼容无关,主要是几个本人在项目中遇到的几个小问题的总结,问题虽小,但是却有时很困扰人,在此记录一下,如果后期有此类问题会持续添加到这里. 1.内联标签之间的空格 正常情况下书写 ...
- Tornado框架
Tornado介绍 Tornado 是 FriendFeed 使用的可扩展的异步非阻塞式 web 服务器及其相关工具的开源版本.这个 Web 框架看起来有些像web.py(豆瓣用这个写的) 或者 Go ...
- .NET 2.0 检测
#include <stdio.h>#include <stdlib.h>#include<windows.h> char GetSystemDisk(){ ...
- var 的使用
List<Enterprise> epList = ViewBag.epList; foreach (var item in epList){ //todo ... } 当 List< ...
- 基于MVC4+EasyUI的Web开发框架经验总结(11)--使用Bundles处理简化页面代码
在Web开发的时候,我们很多时候,需要引用很多CSS文件.JS文件,随着使用更多的插件或者独立样式文件,可能我们的Web界面代码会越来越臃肿,看起来也很累赘,在MVC里面提供了一个Bundle的对象, ...
- iOS阶段学习第15天笔记(NSDate操作)
iOS学习(OC语言)知识点整理 一.OC关于NSDate类的操作实例代码 //默认直接显示对象,显示的是格林威治时间 //获取当前日期时间的实例方法 NSDate *date1=[[NSDate a ...
- js设置和读取cookie
/*path参数:表示cookie所在的目录,.net默认为/(根目录).在同一个服务器上有目录如下:/test/,/test/aa/,/test /bb/,现设一个cookie1的path为/tes ...