文件链接: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. php手册总结(一)

    一:自动加载 __autoload(): 注意: 1:spl_autoload_register() 提供了一种更加灵活的方式来实现类的自动加载.因此,不再建议使用 __autoload() 函数,在 ...

  2. PHP的学习--Traits新特性

    在阅读yii2源码的时候接触到了trait,就学习了一下,写下博客记录一下. 自 PHP 5.4.0 起,PHP 实现了代码复用的一个方法,称为 traits. Traits 是一种为类似 PHP 的 ...

  3. CSS选择器的一些记录

    选择器 例子 例子描述 CSS .class .intro 选择 class="intro" 的所有元素. 1 #id #firstname 选择 id="firstna ...

  4. 漫谈可视化Prefuse(六)---改动源码定制边粗细

    可视化一路走来,体会很多:博客一路写来,收获颇丰:代码一路码来,思路越来越清晰.终究还是明白了一句古话:纸上得来终觉浅,绝知此事要躬行. 跌跌撞撞整合了个可视化小tool,零零碎碎结交了众多的志同道合 ...

  5. [SDK2.2]Windows Azure Virtual Network (4) 创建Web Server 001并添加至Virtual Network

    <Windows Azure Platform 系列文章目录> 在上一章内容中,笔者已经介绍了以下两个内容: 1.创建Virtual Network,并且设置了IP range 2.创建A ...

  6. redis学习之二from github

    大概敲了一遍基本命令,熟悉了redis的存储方式.现在开始进一步系统的学习.学习教程目前计划有三个,一个是github上的https://github.com/JasonLai256/the-litt ...

  7. C#--属性

  8. 【原创】Kakfa network包源代码分析

    kafka.network包主要为kafka提供网络服务,通常不包含具体的逻辑,都是一些最基本的网络服务组件.其中比较重要的是Receive.Send和Handler.Receive和Send封装了底 ...

  9. 【转载】jquery validate验证插件,在ajax提交方式下的验证

    正常的表单都是使用submit按钮来提交,jquery  validate插件可以方便的做表单验证. 做一个发送短信的功能,向目标表插入多条记录,界面采用ajax来提交表单,等待效果直接用ext的遮罩 ...

  10. Nancy 学习-身份认证(Basic Authentication) 继续跨平台

    开源 示例代码:https://github.com/linezero/NancyDemo 前面讲解Nancy的进阶部分,现在来学习Nancy 的身份认证. 本篇主要讲解Basic Authentic ...