前端工程化的探索

2016-08-23 10:07:24 +08:00
 zpczjl

前端工程化的探索

不添加 node 层实现非 SPA 网页开发的前后端分离。

技术栈: webpack + jade + es6 + scss + swig 等

项目 git: webpack-django-starter

需求

成品 beta 版(虽然有广告之嫌):

我们从前怎么做?

之前开发过的一些多页面网站都是在 Django template 目录下直接写 Django 模板(类似于写 PHP 和 JSP ), js 和 css 又要写在 Django 项目的 static 目录下。前端没有工程化,前端代码被肢解分离在后端项目的目录里。做过这样项目的各位攻城狮应该都知道有多痛苦吧。

缺点:

优点:

别人怎么做?

好吧!别人的做法不合适,只能自己想办法了。

我们到底面临的是什么问题?

正如我已经提到的:

之前开发过的一些多页面网站都是在 Django template 目录下直接写 Django 模板(类似于写 PHP 和 JSP ), js 和 css 又要写在 Django 项目的 static 目录下。

仔细想来,其实 Django 只是想要模板和静态资源,我们可以直接在 Django 目录下写,当然也可以开一个前端工程来写,最后把模板和静态资源 copy 到 Django 工程的相应目录下。如下图: 图 1

所以问题就是如何配置一个多页面的前端项目,这个项目

solution

看着这些需求,熟悉 wepack 的各位大神可以已经微微一笑了。大部分的功能用 webpack 都可以轻松实现,不过是一个基于 webpack 的多页面工程嘛。确实如此,把 Django 模板当做一种特别的 html 来看的话,其实就是如此。

唯一的不同点是开发时如何能让 node server 渲染 Django 模板? 我想的办法是在开发时用swig.js来代替 Django 渲染 Django 模板。( swig 模板的语法和 Django 模板语法相似,加之它支持自定义 tag 和 filter )

所以,最终的结构就是这样:

图 2

项目的代码结构:

图 3

  • build 目录下是 webpack 、 express 以及 swig 的配置文件。
  • config 目录下是项目的一些可变配置,比如 release 的路径、是否生成 sourcemap
  • assets 是一些全局资源,比如 favicon
  • common-style 里是一些全局的 css 文件
  • components 里是页面的公用组件 组件的 jade 文件、 scss 文件和 js 文件是组织在一个目录下的
  • pages 里是页面的实现, jade 文件、 scss 文件和 js 文件是同样是组织在一个目录下的
  • mock.js 是开发时 express 、 swig 用于渲染页面的假数据。

图 4

图 5

page 目录下的 jade 文件分为两种:一种是 dj.jade 文件,一种是.jade 文件。前者会被认为是 Django 模板,开发时会被 swig 渲染,发布时会被发布到 template 目录下。后者被认为是纯页面,开发时不会被 swig 渲染, release 时会被放到 static 的 html 目录下。

另外,有时候一些页面是一组页面,他们很大一部分是一样的,比如图 4 中的 about-us 下面有 2 个页面 author 和 company 。此时,可以在 about-us 下面写一个 base ,把公共的内容写在 base 里。而 base 会被识别,在 dev 和 release 时都不会被当做页面处理。(不会生成一个 base 的页面)

写在最后

东西比较多,写的也很乱,感觉很难让大家看明白。。。哈哈。看 code 吧。本项目是我们 team 的一次尝试,我们用这个架构写了 2 个项目,感觉还不错,不需要引入 node 层,前后端彻底分离了,在我们这样的特定项目背景下,比较适用,和大家分享下,希望有用。

( V2EX 上得图片不支持 with 么?图片 size 不能改,大家看的受累了。。)

2008 次点击
所在节点    问与答
2 条回复
hronro
2016-08-23 11:34:16 +08:00
感谢分享
zpczjl
2016-08-23 13:22:46 +08:00
@hronro :)

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/301114

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX