返回介绍

Vdt 实例

发布于 2021-04-10 06:03:37 字数 3912 浏览 817 评论 0 收藏 0

创建Vdt实例

Vdt(template)

  • @param template {String | Function} 用来创建实例的模板,既可以是模板字符串,也可以是模板函数
  • @return {Vdt Object}

通过Vdt(template)方法可以创建一个Vdt实例

var vdt;

// 传入模板字符串
vdt = Vdt('<div></div>');

// 或者,传入模板函数
vdt = Vdt(Vdt.compile('<div></div>'));

属性和方法

vdt.render([data])

  • @description 渲染模板
  • @param data {Object} 用来渲染模板的数据
  • @return {HtmlElement} 返回渲染出来的dom

vdt.renderString([data])

  • @description 渲染模板,结果为html字符串
  • @param data {Object} 用来渲染模板的数据
  • @return {Html String} 返回渲染出来的html字符串

vdt.update([data])

  • @description 更新模板
  • @param data {Object} 用来更新模板的数据,如果传入该数据,则原始数据将会被它替换掉
  • @return {HtmlElement} 返回更新后的dom

vdt.hydrate(data, dom)

  • @description 给已存在的dom建立到vdt的绑定。这在前后端同构的项目中,可以用于前端混合
  • @param data {Object} 用来混合的数据
  • @param dom {HtmlElement} 将要混合的dom元素
  • @return {HtmlElement} 返回混合后的dom

vdt.data

  • @description 指向渲染/更新模板的数据

创建Vdt实例后,通过render()方法,传入数据即可渲染出需要的dom节点,后续可以通过update()方法去更新dom

var data = {a: 1};
vdt.render(data);

vdt.data === data; // true
vdt.data.vdt === vdt; // true

// 更新
var newData = {a: 2};
vdt.update(newData);

// 不传入新数据,而是修改原始数据去更新
vdt.data.a = 3;
vdt.update();

vdt.node

  • @description 指向渲染/更新模板后的dom

vdt.template

  • @description 指向实例的模板函数

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文