文件链接: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();
}

组件内部定义了两个方法:

changePageloadData;

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属性监听了两个变量:

optionspagination:

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设计说明文档的更多相关文章

  1. PowerDesigner中导出设计说明文档

    点击下图的新建按钮,新建一个导出内容的模板 模板设计界面分为2栏,左边是可选的模板内容,右侧是模板,双击左侧条目会添加到右侧,最后生成的文件中就有此项内容. 已经添加到右侧的内容可以编辑,双击右侧的条 ...

  2. Net 通用权限管理系统源码 带数据库设计文档,部署说明文档

    Net 通用权限管理系统源码 带数据库设计文档,部署说明文档 包括数据库设计文档部署安装文档源码数据库文件 下载地址:http://www.mallhd.com/archives/1389

  3. SWFUpload 2.5.0版 官方说明文档 中文翻译版

    原文地址:http://www.cnblogs.com/youring2/archive/2012/07/13/2590010.html#setFileUploadLimit SWFUpload v2 ...

  4. ICE中间件说明文档

    ICE中间件说明文档 1       ICE中间件简介 2       平台核心功能 2.1        接口描述语言(Slice) 2.2        ICE运行时 2.2.1         ...

  5. Eclipse用法和技巧四:生成说明文档1

    写代码经常要添加注释的,java代码的注释也可以分为两种.单行注释以“//”作为开头就可以.段落注释在第一行开头添加“/*”,在最后一行结尾添加“*/"即可.这里介绍一种添加注释的方法,其注 ...

  6. vnpy官网说明文档网址

    接触VNPY一年多,一直对作者设计原理和思想有所困惑.发一篇vnpy官网的说明文档,便于以后理解项目代码. http://www.vnpy.org/archives.html

  7. 为ASP.NET WEB API生成人性化说明文档

    一.为什么要生成说明文档 我们大家都知道,自己写的API要供他人调用,就需要用文字的方式将调用方法和注意事项等写成一个文档以更好的展示我们设计时的想法和思路,便于调用者更加高效的使用我们的API. 当 ...

  8. INSPIRED启示录 读书笔记 - 第18章 重新定义产品说明文档

    理想的产品说明文档 1.产品说明文档应该完整地描述用户体验——不只是用户需求,还包括交互设计和视觉设计.用户需求和用户体验是密不可分的 2.产品说明文档必须准确地描述软件的行为 3.产品说明文档必须以 ...

  9. ES SQL使用说明文档

    ES SQL使用说明文档 一.Elasticsearch术语介绍 l  接近实时(NRT): Elasticsearch 是一个接近实时的搜索平台.这意味着,从索引一个文档直到这个文档能够被搜索到有一 ...

随机推荐

  1. Android在一个Activity中关闭另一个Activity

    比如有ActivityA, ActivityB,在ActivityB中关闭ActivityA. 解决方案: 1.在 ActivityA 里面设置一个静态的变量instance,初始化为this,在 A ...

  2. Deep learning:四十九(RNN-RBM简单理解)

    前言: 本文主要是bengio的deep learning tutorial教程主页中最后一个sample:rnn-rbm in polyphonic music. 即用RNN-RBM来model复调 ...

  3. WOW.js – 在页面滚动时展现动感的元素动画效果

    在一些网页上,当你滚动页面的时候会看到各式各样的元素动画效果,非常动感.WOW.js 就是一款帮助你实现这种 CSS 动画效果的插件,很容易定制,你可以改变动画设置喜欢的风格.延迟.长度.偏移和迭代等 ...

  4. 对比MFC资源文件谈谈WPF布局方式

    对比MFC资源文件谈谈WPF布局方式 MFC方式 对于传统的MFC基于UI的应用程序设计通常分两步走,首先是设计UI,使用的是RC文件,然后是代码文件,对RC文件进行操作,如下面Figure 1 的基 ...

  5. 【Swift学习】Swift编程之旅---继承(十七)

    在 Swift 中,继承是区分「类」与其它类型的一个基本特征.swift不支持多重继承.类可以调用和访问超类的方法,属性和subscripts下标,并且可以重写(override)这些方法,属性和附属 ...

  6. EDNS

    随着业务的复杂化和多样化,RFC1035中定义的DNS消息格式和它支持的消息内容已经不足以满足一些DNS服务器的需求,于是,RFC2671中提出了一种扩展DNS机制EDNS(Extension Mec ...

  7. jdk源码分析之ArrayList

    ArrayList关键属性分析 ArrayList采用Object数组来存储数据 /** * The array buffer into which the elements of the Array ...

  8. 【原创】asp.net导出word 检索 COM 类工厂中 CLSID 为 {000209FF-0000-0000-C000-000000000046} 的组件失败,原因是出现以下错误: 8000401a

    我的服务器:windows server 2008(64位)+microsoft office 2007 企业版 业务:网站导出应聘word简历. 出现以下错误: 检索 COM 类工厂中 CLSID ...

  9. C# WebClient 使用http免费代理。

    static void Main(string[] args) { WebClient client = new WebClient(); client.Encoding = Encoding.Get ...

  10. C++: read SQL server data using System::Data::SqlClient

    stdafx.h: // stdafx.h : include file for standard system include files, // or project specific inclu ...