热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

闲话js前端框架(5)——再看自己一年前设计的微型渲染引擎

闲话js前端框架前端人员美工+设计+代码+测试——题记专题文章:一、从avalonjs的模板说起二、庞大的angularjs三、再也不想碰DOM四、组件化?有

闲话js前端框架

前端人员=美工+设计+代码+测试
——题记

专题文章:

一、从avalonjs的模板说起
二、庞大的angularjs
三、再也不想碰DOM
四、组件化?有没有后端的事?
五、再看自己一年前设计的微型渲染引擎
六、在浏览器标准上做文章
七、抛开浏览器,构建应用容器
八、为何Flash、银光和Java都在网页端一蹶不振

本文属 西风逍遥游 原创, 转载请注明出处: 西风世界 http://blog.csdn.net/xfxyy_sxfancy

五、再看自己一年前设计的微型渲染引擎

在做了一年网站期间,我主要是以一个后端的身份在工作,有时是php,有时JavaEE,还有python,最常见的工作就是,写一个接口,将接口获得的数据判断一下异常,然后修改格式存入数据库中。

而我做前端的工作,屈指可数,就偶尔用下avalon,有时用下angularjs,其他的几乎没动过。但我在初学前端的时候,却做过一个现在我看来都是天方夜谭的设计,我制作了一个小型渲染引擎,我给他起名ntml(即将崩坏的html)。

需要引入jQuery的引擎

说这货是个引擎我也是无奈了。

首先,只有一个js类,手动导出符号,还没写闭包。使用前还需要提前引入jQuery。。。
我真想说这货是一个jQuery插件 - -!但他连插件都不算!

引入jQuery的原因其实很简单,从当时直到现在,我都不会封装跨平台的ajax函数!还有xml解析函数!

引擎的功能呢?

说起来挺好玩,一共200多行js代码,又引入了别人的一个库,实现了这个功能,将这样的代码:

 
<ntml>
<nt-container nt-var=''>
  <nt-layout-8-4>
    <a-left>
      <nt-article>
        <a-title>关于nt语法的一些介绍a-title>
        <a-content>
          下面我们来简要介绍一下ntml这种标记式语言。
        a-content>
      nt-article>
    a-left>
    <a-right>
      <nt-loginform>
        <params action='#' method='get' />
      nt-loginform>
    a-right>
  nt-layout-8-4>
nt-container>
ntml>

渲染成这个样子:

这里写图片描述

有没有觉得很有趣?

不过功能确实不多,也就仅仅是这样一个功能,甚至连什么事件绑定啊,都没有做。
当然,这里所展示的代码并不完全,他的工作原理实际上是将xml中声明的标签,依次替换为template下预先写好的模板。对应需要有嵌套的部分,也用属性指定好每个对应的模板标签就可以了。

ntml语法规范

所有需要被ntml解析的标签前,可以加上’nt-‘,用来被解释器识别。’nt-‘是标准ntml组件库的前缀,你也可以自己规定名称前缀。
eg.

  <nt-login_form class='col-xs-12 col-xs-4'>
  nt-login_form>

nt对象下面的子对象,所有加’nta-‘前缀的,认为是nt语法中的属性
eg.

  <nt-article class='col-xs-12 col-xs-8'>
    <a-title>关于nt语法的一些介绍a-title>
    <a-date>2014-8-10a-date>
    <a-content>
      下面我们来简要介绍一下ntml这种标记式语言。
      <nt-ad class='col-xs-12 col-xs-8'>

      nt-ad>
    a-content>
  nt-article>

nt对象中的params标签下的属性会被解释为声明,内容会被解释为content
eg.

  <nt-article class='col-xs-12 col-xs-8'>
    <params title='关于nt语法的一些介绍' date='2014-8-10' >
      下面我们来简要介绍一下ntml这种标记式语言。
      <nt-ad class='col-xs-12 col-xs-8'>

      nt-ad>
    a-params>
  nt-article>

nt对象中非nta前缀的标签也会被解释为content
eg.

  <nt-article class='col-xs-12 col-xs-8'>
    <a-params title='关于nt语法的一些介绍' date='2014-8-10' />
    下面我们来简要介绍一下ntml这种标记式语言。
    <nt-ad class='col-xs-12 col-xs-8'>

    nt-ad>
  nt-article>

如果同时存在多个content位置的内容的话,会被从上到下依次添加

nt组件模板的开发
nt解析器会将最外层的标签解释为div,所以不必再增加嵌套div。
eg.

   xml version="1.0" encoding="utf-8" ?> 
  <div style='align-center;'>
    <h1>{{#title}}h1>
    <h5>{{#date}}h5>
  div>
  <p>
    {{#content}}  
  p>

我们使用artTemplate模板引擎,建议将模板编译成js代码,使用TmodJS工具。

遗憾

这个渲染引擎最大的问题既不是效率问题,又不是功能问题,而是模板引擎的选用上。当时并不怎么了解前端,选用了一款静态引擎进行渲染。这就造成了一个问题,这个引擎估计比较适合用在后端。。。
也就是说,本来是想开发一个易用的前端引擎,却不慎做成了nodejs用的后端引擎- -!

总结教训

当初的设计确实是有很多问题的,但我希望这个设计能为之后的考虑做铺路的打算。这个项目的初衷是用模块化的xml来解决组件化难题,但却受能力所限,写出来的渲染器并不好用。得到两点经验,其一,DOM操作的封装要优于简单的文本格式化;其二,组件化要有js的支撑才能灵活,想要简单通过模拟后端工作的方式,既不能改善结构,又不能让其具有相应的灵活性。

什么样的框架是理想的?

我一直觉得应该有一种方式,让网站模块化工作,首先,虚拟DOM是一个好想法,但我不大喜欢React的复杂,我希望还是用动态模板的哪种简单方式操作DOM。
既然要大规模组件化,就要让组件十分好写,我个人反感复杂的组件编写阅读,希望找到一种方式能够简单的声明组件,无需js,就能引入组件,我希望通过约定配置,将组件化做的更方便。

想看看完整的情况

Github仓库地址: https://github.com/sunxfancy/ntml
欢迎前来fork和提意见,拿来改着玩神马的都可以。
~~(>_<)~~ ,发布已经一年了,一个看的也没有,忽然发现没写Readme!
只能怪我那时太年轻


推荐阅读
  • 探索JavaScript倒计时功能的三种高效实现方法及代码示例 ... [详细]
  • 本课程详细介绍了如何使用Python Flask框架从零开始构建鱼书应用,涵盖高级编程技巧和实战项目。通过视频教学,学员将学习到Flask的高效用法,包括数据库事务处理和书籍交易模型的实现。特别感谢AI资源网提供的课程下载支持。 ... [详细]
  • 本文详细解析了JSONP(JSON with Padding)的跨域机制及其工作原理。JSONP是一种通过动态创建``标签来实现跨域请求的技术,其核心在于利用了浏览器对``标签的宽松同源策略。文章不仅介绍了JSONP的产生背景,还深入探讨了其具体实现过程,包括如何构造请求、服务器端如何响应以及客户端如何处理返回的数据。此外,还分析了JSONP的优势和局限性,帮助读者全面理解这一技术在现代Web开发中的应用。 ... [详细]
  • 如何在Java中高效构建WebService
    本文介绍了如何利用XFire框架在Java中高效构建WebService。XFire是一个轻量级、高性能的Java SOAP框架,能够简化WebService的开发流程。通过结合MyEclipse集成开发环境,开发者可以更便捷地进行项目配置和代码编写,从而提高开发效率。此外,文章还详细探讨了XFire的关键特性和最佳实践,为读者提供了实用的参考。 ... [详细]
  • 本文提供了 RabbitMQ 3.7 的快速上手指南,详细介绍了环境搭建、生产者和消费者的配置与使用。通过官方教程的指引,读者可以轻松完成初步测试和实践,快速掌握 RabbitMQ 的核心功能和基本操作。 ... [详细]
  • 深入解析Wget CVE-2016-4971漏洞的利用方法与安全防范措施
    ### 摘要Wget 是一个广泛使用的命令行工具,用于从 Web 服务器下载文件。CVE-2016-4971 漏洞涉及 Wget 在处理特定 HTTP 响应头时的缺陷,可能导致远程代码执行。本文详细分析了该漏洞的成因、利用方法以及相应的安全防范措施,包括更新 Wget 版本、配置防火墙规则和使用安全的 HTTP 头。通过这些措施,可以有效防止潜在的安全威胁。 ... [详细]
  • 在2020年8月19日的深度分析中,我们探讨了HTML标签中同时存在`a`标签的`href`和`onclick`属性时的触发顺序问题。此外,还讨论了如何在一个自适应高度的父级`div`中,使两个子`div`中的一个固定高度为300px,另一个自动填充剩余空间的方法。最后,文章详细介绍了JavaScript异步加载的多种实现方式,包括但不限于`async`、`defer`属性以及动态脚本插入技术,为开发者提供了丰富的技术参考。 ... [详细]
  • 在ASP.NET MVC项目中,通过实战解决了Ajax请求500错误及多表数据查询的问题。具体而言,将页面分为两个部分,用户点击右侧导航栏时,通过Ajax请求动态加载数据,并在右侧显示相应的页面内容。最初尝试使用Partial Action方法,但遇到了500错误。通过详细排查和调试,最终成功解决了这一问题,并实现了预期功能。此外,还优化了多表数据查询的性能,确保系统的高效运行。 ... [详细]
  • jQuery Flot 数据可视化插件:高效绘制图表的专业工具
    jQuery Flot 是一款高效的数据可视化插件,专为绘制各种图表而设计。该工具支持丰富的图表类型和自定义选项,适用于多种应用场景。用户可以通过其官方网站获取示例代码和下载资源,以便快速上手和使用。 ... [详细]
  • 本文探讨了如何在 Google Sheets 中通过自定义函数实现 AJAX 调用。具体介绍了编写脚本的方法,以便在电子表格中发起 AJAX 请求,从而实现数据的动态获取与更新。这种方法不仅简化了数据处理流程,还提高了工作效率。 ... [详细]
  • 本文详细探讨了Java集合框架的使用方法及其性能特点。首先,通过关系图展示了集合接口之间的层次结构,如`Collection`接口作为对象集合的基础,其下分为`List`、`Set`和`Queue`等子接口。其中,`List`接口支持按插入顺序保存元素且允许重复,而`Set`接口则确保元素唯一性。此外,文章还深入分析了不同集合类在实际应用中的性能表现,为开发者选择合适的集合类型提供了参考依据。 ... [详细]
  • 作为140字符的开创者,Twitter看似简单却异常复杂。其简洁之处在于仅用140个字符就能实现信息的高效传播,甚至在多次全球性事件中超越传统媒体的速度。然而,为了支持2亿用户的高效使用,其背后的技术架构和系统设计则极为复杂,涉及高并发处理、数据存储和实时传输等多个技术挑战。 ... [详细]
  • 本文介绍了使用 Python 编程语言高效抓取微博文本和动态网页图像数据的方法。通过详细的示例代码,展示了如何利用爬虫技术获取微博内容和动态图片,为数据采集和分析提供了实用的技术支持。对于对网络数据抓取感兴趣的读者,本文具有较高的参考价值。 ... [详细]
  • 如何构建基于Spring MVC框架的Java Web应用项目
    在构建基于Spring MVC框架的Java Web应用项目时,首先应创建一个新的动态Web项目。接着,需将必要的JAR包导入至WebContent/WEB-INF/lib目录下,确保包括Spring核心库及相关依赖。如遇缺失的JAR包,可向社区求助或通过Maven等工具自动下载。正确配置后,即可开始搭建应用结构与功能模块。 ... [详细]
  • Spring注解开发指南:@Resource与@Component详解 ... [详细]
author-avatar
瓜子HR刘冲
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有