Skip to content

Latest commit

 

History

History
122 lines (94 loc) · 4.7 KB

README.md

File metadata and controls

122 lines (94 loc) · 4.7 KB

XuebaOnline

目录结构

  • semantic 下为Semantic-UI的源码, 后期需要对其中的主题和我们不太满意的效果等进行定制。

  • semantic.json 编译Semantic-UI所使用的配置文件。 后期如果需要,我们可以自己裁剪Semantic-UI,以减少文件体积。

  • XuebaOnline XuebaOnline的Django项目。 我们主要的开发工作在这里进行。

XuebaOnline下属的XuebaOnline是最主要的一个APP,负责主界面的效果。 各个模块可以考虑开发为单独的APP形式,这样有利于协同。

每个APP下属目录按照Django的默认目录结构进行布局:

  • templates下放置前端模版(.djhtml)

  • static下放置静态文件,如CSS、JS脚本、图片素材等

关于accounts App

  • 与用户相关的数据和页面都放在该App下

  • 所有和用户直接相关的页面放在accounts/templates/中

    • sign in
    • sign up
    • user home
    • ......
  • 所以程序的运行过程中将获取的url拿到XuebaOnline下的urls.py中寻找,然后通过url(r'^accounts/', include(accounts_urls)),转到accounts下的urls.py中寻找。然后views.py中加载模板时都是从views.py同目录下的templates/文件夹中。

关于template路径的问题:

  • 注意尽管是在accounts中,如果extends某个模板,比如base.djhtml,引用的还是XuebaOnline下的那个。

环境配置

前端开发环境安装

Windows平台安装Node.js

下载Windows平台的Node.js环境安装包首先需要确认要确保System byte和安装包匹配,否则可能在后期安装时出现不可预期的错误

  • 首先访问Node.js的Download页面,这里笔者推荐下载Windows Installer (.msi)类型的文件下载,直接依据默认的安装目录完成安装即可

Node.js下载页面图例(Windows)

特别说明,安装时需要确保npm同时被正确安装如下图所示: npm安装确认图例

Linux平台安装Node.js

  • 首先访问Node.js的Download页面,这里笔者特别说明,Linux平台可以选择Linux Binaries (.tar.gz)类型文件或者Source Code类型文件进行安装,在后面会对这两者进行区分

Node.js下载页面图例(Linux)

Linux Binaries (.tar.gz)

  • 解压后bin文件夹中已存在node和npm
cd node-v0.10.28-linux-x64/bin
ls
./node -v
  • 设置全局
ln -s /home/……/node-v0.10.28-linux-x64/bin/node /usr/local/bin/node
ln -s /home/……/node-v0.10.28-linux-x64/bin/npm /usr/local/bin/npm

/home/……/这一路径是笔者自己设置的,可以依据解压目录自行设置即可

Source Code

#  tar xvf node-v0.10.28.tar.gz 
#  cd node-v0.10.28 
#  ./configure 
#  make 
#  make install 
#  cp /usr/local/bin/node /usr/sbin/ 
#  node -v 

特别说明:node -v指令用于查看当前安装的Node版本

前端开发环境及其Django整合

首先,安装前端开发的各类依赖,包括Webpack、Semantic-UI、ReactJS等。

npm install --save-dev react react-dom
npm install --save semantic-ui
npm install --save-dev webpack webpack-bundle-tracker babel babel-loader babel-core babel-preset-es2015 babel-preset-react css-loader style-loader file-loader 
npm install --save react-tagcloud marked

安装Webpack与Django的整合

pip install django-webpack-loader

之后,为了实时加载变更的模块,我们还需要做一些工作

npm install --save-dev webpack-dev-server react-hot-loader

整个前端应用采用Facebook提倡的Flux架构(毕竟我们使用了ReactJS嘛),然而,经过查阅资料, Facebook官方的Flux实现并不是大家首推的Flux实现。我们选择了大家评价比较高的Alt。 所以,接下来,我们还需要按照Alt

    npm install --save-dev alt

运行

编译采用

./node_modules/.bin/webpack --config webpack.config.js

实时编译(hot load,即无需刷新网页即可看到效果变化)

node server.js

Django运行

python3 manage.py runserver