博客
关于我
简单模板模式
阅读量:404 次
发布时间:2019-03-06

本文共 2854 字,大约阅读时间需要 9 分钟。

简单模板模式是一种通过格式化字符串拼接来生成视图的技术,旨在减少视图层面上的节点操作,从而解决数据与结构的强耦合性问题。与模板方法模式相比,它更注重技术实现的简洁性和灵活性。

节点操作

在传统的节点操作中,生成列表往往涉及繁琐的DOM操作。例如:

const list = [  { name: 'Google', url: 'https://www.google.com' },  { name: 'Baidu', url: 'https://www.baidu.com' },  { name: 'Bing', url: 'https://cn.bing.com' }];const root = document.getElementById('root');const ul = document.createElement('ul');list.forEach((item) => {  const li = document.createElement('li');  const a = document.createElement('a');  a.href = item.url;  a.target = '_blank';  a.innerText = item.name;  li.appendChild(a);  ul.appendChild(li);});root.appendChild(ul);

这种方法虽然功能上可行,但当数据规模扩大时,代码的可读性和维护性会显著下降。

基于字符串拼接的实现

为了减少节点操作的复杂性,开发者常常采用字符串拼接的方式。例如:

const template = `
`;root.innerHTML = template;

这种方法虽然简化了操作,但由于字符串与数据的强耦合,一旦数据或结构发生变化,整个视图就需要重新生成,导致维护成本上升。

模板渲染

为了进一步提升代码的可读性,开发者引入了模板渲染的概念。通过将数据格式化到模板字符串中,实现视图的渲染。例如:

const formatString = (str, data) => {  return str.replace(/\{\{(\w+)\}\}/g, (match, key) => data[key]);};const template = ['
    '];list.forEach((item) => { template.push( `
  • ${name}
  • ` .replace('{{url}}', item.url) .replace('{{name}}', item.name) );});template.push('
');root.innerHTML = template.join('');

这种方法通过动态替换模板字符串,显著提升了代码的可读性和维护性。

模板引擎的简单实现

为了更灵活地处理模板语法,开发者常常使用模板引擎。例如,可以通过以下方法实现简单的模板语法:

function render(element, data) {  const originString = element.innerHTML;  let html = originString    .replace(/"/g, '\\\"')    .replace(/\s+/g, ' ')    .replace(/\{\{(.+?)\}\}/g, (match, key) => data[key]);  html = `var targetHTML = "${html}";return targetHTML;`;  const parsedHTML = new Function(...Object.keys(data))(...Object.values(data));  element.innerHTML = parsedHTML;}

通过这种方式,开发者可以在模板字符串中嵌入多种数据字段,并在需要时动态替换内容。

AST解析

为了进一步优化模板渲染过程,开发者可以采用AST(抽象语法树)解析的方式。例如:

function parseAST(root) {  const node = {    parent: null,    type: 'tag',    tagName: root.localName,    children: [],    attr: {}  };  Array.from(root.attributes).forEach(item => {    node.attr[item.name] = item.value;  });  Array.from(root.childNodes).forEach(child => {    const childNode = parseAST(child);    childNode.parent = node;    node.children.push(childNode);  });  return node;}function generateHTMLTemplate(AST) {  let template = '';  function traverse(node) {    if (node.type === 'tag') {      template += `<${node.tagName}>`;      traverse(node.children[0]);      traverse(node.children[1] || node.children[2] || node.children[3]);      template += `
`; } else { template += node.content; } } traverse(AST); return template;}const root = document.getElementById('root');const ast = parseAST(root);const template = generateHTMLTemplate(ast);render(root, template, data);

这种方式通过解析模板字符串为AST,进一步提升了渲染效率,特别是在数据频繁变动的情况下。

每日一题

GitHub - WindrunnerMax/EveryDay

参考

  • Juejin - 模板引擎实现
  • Libin的博客 - 模板模式
  • LayUI模板引擎
  • 你可能感兴趣的文章
    Nginx配置——不记录指定文件类型日志
    查看>>
    Nginx配置代理解决本地html进行ajax请求接口跨域问题
    查看>>
    Nginx配置参数中文说明
    查看>>
    Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
    查看>>
    Nginx配置如何一键生成
    查看>>
    Nginx配置实例-负载均衡实例:平均访问多台服务器
    查看>>
    NHibernate学习[1]
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
    查看>>
    NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
    查看>>
    NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
    查看>>
    NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001---大数据之Nifi工作笔记0068
    查看>>
    NIFI集群_内存溢出_CPU占用100%修复_GC overhead limit exceeded_NIFI: out of memory error ---大数据之Nifi工作笔记0017
    查看>>
    NIFI集群_队列Queue中数据无法清空_清除队列数据报错_无法删除queue_解决_集群中机器交替重启删除---大数据之Nifi工作笔记0061
    查看>>
    NIH发布包含10600张CT图像数据库 为AI算法测试铺路
    查看>>
    Nim教程【十二】
    查看>>