上一篇,我讲述了植入式Web前端开发的基本情况,本篇就来探究其开发方法。以下假定CMS只能植入前端代码,并且需求规模是任意大小的。

代码形式

HTML代码是直接植入的毫无疑问,但除非植入的代码非常简短、功能独立,且植入点数量不多,否则将CSS和JavaScript代码直接嵌入在HTML代码中是不明智的(有的CMS可直接植入CSS和JavaScript代码,其本质也是将这些代码直接嵌入在HTML中),主要有以下弊端:

  • 降低性能:CSS和JavaScript代码不会被浏览器缓存。
  • 不方便调试:每次代码修改都要重新提交到系统中;代码量比较大时,混杂在一起难以书写。
  • 不方便管理:植入点比较多时,尤其是有公共代码时,难以清晰地管理。

更好的办法是,将CSS和JavaScript做成单独的文件,在植入的HTML代码中通过<link rel="stylesheet"><script>标签引用之。

通常,CMS会提供资源文件上传的功能。可以先在本地开发好CSS和JavaScript文件,再上传到CMS中,然后使用上传后CMS提供的文件URL。如果CMS不提供这种功能,也有其他各种办法,只要使得CSS和JavaScript文件能被公网访问即可。

开发环境

通常,在CMS上提交代码是立即生效的,所以不能直接在用户使用的页面(即生产页面)上一点点地开发和提交。一个可行的办法是,专门设立一个用户不会访问的、仅供开发用的页面,在此页面上开发,待代码稳定之后,再提交到生产页面上。

通常,开发时HTML代码部分是改动比较少的,更频繁改动的是CSS和JavaScript代码。在使用独立文件时,必须保证页面引用的CSS和JavaScript文件始终是最新的。如果它们在远程主机上,这种保证比较麻烦,一般要频繁上传文件。更好的办法是,在本地建立一个Web服务器来提供这些CSS和JavaScript文件

在本地机器上建立一个Web服务器,让正在开发的CSS和JavaScript文件能够通过这个服务器访问到。然后在开发页面的植入代码中引用本地服务器上URL(可以在URL末尾加一个?,让浏览器不缓存)。这样,只需要刷新一下页面,无需重新提交,最新的CSS和JavaScript代码就立即生效了。

当代码稳定时,再将文件一次性上传到生产环境中,然后修改HTML中的引用的URL为生产环境中的URL(末尾无?),提交到生产页面即可。

在HTML代码不需要修改的情况下,甚至可以直接在生产页面上做开发。

在hosts中将生产环境提供CSS和JavaScript文件的主机域名指向到本机,然后在本地Web服务器中绑定该域名,并使得文件的访问路径与生产环境完全一致,最好再设置CSS和JavaScript文件不缓存。如果是HTTPS访问,则还需要做一个自签名证书,并在浏览器中忽略证书问题继续访问。如此,在本机,生产页面中获取文件时实际上会从本地获取,而用户的访问仍然正常基于生产环境。

更多

到这里,已经可以看到,除了代码部署方式有些特殊,其他方面实际上跟正常的前端开发没什么区别。因此,各种前端开发技术、工具实际上都可以使用,如多文件开发然后编译成单文件、代码压缩、Git版本控制等等。

如果规模比较大,还可以专门开发一个自动部署机制来做植入代码的持续集成。

植入式Web前端开发方法的更多相关文章

  1. 植入式Web前端开发

    在博客园.凡科建站和其他的一些CMS系统中,提供有允许管理者向网页中插入自定义HTML代码的功能,我将其称之为"植入式"的Web前端代码. 因为CSS和JavaScript可以直接 ...

  2. 指尖下的js ——多触式web前端开发之一:对于Touch的处理

    指尖下的js ——多触式web前端开发之一:对于Touch的处理 水果公司的那些small and cute的设备给我们提供了前所未有的用户体验.当用户在iphone和ipad上运指如飞的时候,那些使 ...

  3. 指尖下的js —— 多触式web前端开发之三:处理复杂手势(转)

    这篇文章着重介绍多触式设备上特有的gesture event(android和iOS对这个事件的封装大同小异).这个事件是对touch event的更高层的封装,和touch一样,它同样包括gestu ...

  4. Web前端开发实战6:CSS实现导航菜单结合二级下拉式菜单的简单变换

    前面几篇博文都在讲导航菜单和二级下拉式菜单,事实上有非常多方法都能够实现的.详细的情况还要视情况而定. 在后面学习到jQuery框架之后,会有更丰富的动画效果.因为在学习Ajax和jQuery的初步阶 ...

  5. Web前端开发实战1:二级下拉式菜单之CSS实现

    二级下拉式菜单在各大学校站点.电商类站点.新闻类站点等大型?站点非经常见,那么它的实现原理是什么呢? 学习了Web前端开发的知识后,我们是能够实现这种功能的.复杂的都是从基础效果上加入做出来的.原理和 ...

  6. web前端开发与iOS终端开发的异同[转]

    * {-webkit-tap-highlight-color: rgba(0,0,0,0);}html {-webkit-text-size-adjust: none;}body {font-fami ...

  7. 用grunt搭建web前端开发环境

    1.前言 本文章旨在讲解grunt入门,以及讲解grunt最常用的几个插件的使用. 2.安装node.js Grunt和所有grunt插件都是基于nodejs来运行的,如果你的电脑上没有nodejs, ...

  8. web前端开发学习内容

    应该 具备的 知识技能 :懂web标准,熟练手写 xhtml css3 并符合 符合w3c标准                       代码能 兼容主流浏览器.ie6.7.8.9 ff 等.    ...

  9. 【转载】WEB前端开发规范文档

    本文转载自谈笑涧<WEB前端开发规范文档> 为 新项目写的一份规范文档, 分享给大家. 我想前端开发过程中, 无论是团队开发, 还是单兵做站, 有一份开发文档做规范, 对开发工作都是很有益 ...

随机推荐

  1. Adaptive AUTOSAR 学习笔记 12 - 通信管理

    本系列学习笔记基于 AUTOSAR Adaptive Platform 官方文档 R20-11 版本 AUTOSAR_EXP_PlatformDesign.pdf 缩写 CM:Communicatio ...

  2. DVWA靶场练习-Command Injection命令注入

    Command Injection 原理 攻击者通过构造恶意参数,破坏命令的语句结构,从而达到执行恶意命令的目的.

  3. 原生js 以ajax(post)的方式传json至php,并让php解析为数组

    如题. 比如要把一个json,如 json= {name:"John Rambo", time:"3pm"},,通过js ,传到一个php服务器 fwq.php ...

  4. flink clickhouse-jdbc和flink-connector 写入数据到clickhouse因为jar包冲突导致的60 seconds.Please check if the requested resources are available in the YARN cluster和Could not resolve ResourceManager address akka报错血案

    一.问题现象,使用flink on yarn 模式,写入数据到clickhouse,但是在yarn 集群充足的情况下一直报:Deployment took more than 60 seconds. ...

  5. JStorm:概念与编程模型

    1.集群架构 JStorm从设计的角度,就是一个典型的调度系统,简单集群的架构如下图所示,其中Nimbus可增加一个备节点,多个Supervisor节点组成任务执行集群. 1.1.Nimbus Nim ...

  6. noip9

    T1 本次考试最水的一道题,然而我sb,前一个小时,找了一大堆跟题目无关的性质,干脆打了个20pts的表,然后就走了,最后几分钟才看出来,匆匆码出来,结果段错误,然后考试就结束了. 好吧,段错误是UB ...

  7. python中的logging日志

    logging使用 import logging import os from logging import handlers from constants.constants import Cons ...

  8. c#反射入门篇(Reflection)——MethodInfo 发现方法的属性

    网站:https://www.jianshu.com/p/52dc85668d00 也算记录自己的学习篇=.= 适合入门看 这里简单介绍下MethodInfo和他基本的几个方法 简介 MethodIn ...

  9. uwp 之语音识别

    xml code ---------------------------------------------- <Page x:Class="MyApp.MainPage" ...

  10. new[]/delete[]与new/delete区别

    new[]/delete[]与new/delete完全不同-动态对象数组创建通过new[] 完成-动态对象数组的销毁通过delete[]完成-new[]/delete[]能够被重载,进而改变内存管理方 ...