摘要:写在前面为了解决后端人员不足又招聘不到的问题,决定用前后端分离的方式写项目,于是尝试用跟搭建一个项目。首先,看一下我搭建的前端跟项目的结构。
写在前面
为了解决后端人员不足又招聘不到的问题,决定用前后端分离的方式写项目,于是尝试用django-rest-framework跟Vue.js搭建一个项目。
基础搭建项目的参考了一下教程使用Django + Vue.js快速而优雅地构建前后端分离项目
整体来说教程写的还可以,但是实际搭完之后,其实还是有很多问题需要解决。
首先,看一下我搭建的前端跟项目的结构。
结构 web pack.config.jsvar path = require("path") var webpack = require("webpack") module.exports = { entry:{ build:"./src/main.js", index:"./src/index.js", foot:"./src/foot.js", login:"./src/login.js", about_us:"./src/about_us.js", sideList:"./src/sideList.js", }, output: { path: path.resolve(__dirname, "./dist/"), publicPath: "/dist/", filename: "static/js/[name].js" }, module: { rules: [ { test: /.vue$/, loader: "vue-loader", options: { loaders: { // Since sass-loader (weirdly) has SCSS as its default parse mode, we map // the "scss" and "sass" values for the lang attribute to the right configs here. // other preprocessors should work out of the box, no loader config like this necessary. "scss": "vue-style-loader!css-loader!sass-loader", "sass": "vue-style-loader!css-loader!sass-loader?indentedSyntax" } // other vue-loader options go here } }, { test:/.css$/, loader:"style-loader!css-loader" }, { test: /.js$/, loader: "babel-loader", exclude: /node_modules/ }, { test: /.(png|jpg|gif|svg)$/, loader: "file-loader", options: { name: "static/img/[name].[ext]?[hash]" } } ] }, resolve: { alias: { "vue$": "vue/dist/vue.esm.js" } }, devServer: { historyApiFallback: true, noInfo: true }, performance: { hints: false }, devtool: "#eval-source-map" } if (process.env.NODE_ENV === "production") { module.exports.devtool = "#source-map" // http://vue-loader.vuejs.org/en/workflow/production.html module.exports.plugins = (module.exports.plugins || []).concat([ new webpack.DefinePlugin({ "process.env": { NODE_ENV: ""production"" } }), new webpack.optimize.UglifyJsPlugin({ sourceMap: true, compress: { warnings: false } }), new webpack.LoaderOptionsPlugin({ minimize: true }) ]) }
我把Django的static文件直接指向了dist.
在settings.py中设置。
STATIC_URL = "/fontend/dist/static/"
STATIC_ROOT = os.path.join(PROJECT_ROOT, "../fontend/dist/static")
Vue实现单页面渲染,把单个页面的css都压缩到js中,index.html页面代码直接引用一个js即可。
有个问题需要解决,就是这种目录结构下,vue的根目录是从dist开始,索引不到fontend,
而django是从fontend开始,所以上述路径/dist/static/js/index.js,vue是可以访问到的,而django访问不到,想让django访问到,就在访问静态文件时改写静态文件的路径。在urls.py中加入这样一行
from django.views.static import serve from mainsys import settings url(r"^(?P.*)$", serve, {"document_root": settings.DOCUMENT_ROOT, "show_indexes": True}),
其中settings.py设置。
DOCUMENT_ROOT = os.path.join(BASE_DIR, "fontend/")
先写这么多,以后遇到坑的时候再更新。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/45445.html
摘要:写在前面为了解决后端人员不足又招聘不到的问题,决定用前后端分离的方式写项目,于是尝试用跟搭建一个项目。首先,看一下我搭建的前端跟项目的结构。 写在前面 为了解决后端人员不足又招聘不到的问题,决定用前后端分离的方式写项目,于是尝试用django-rest-framework跟Vue.js搭建一个项目。 基础搭建项目的参考了一下教程使用Django + Vue.js快速而优雅地构建前后端分...
阅读 2892·2021-11-25 09:43
阅读 3593·2021-08-31 09:41
阅读 1197·2019-08-30 15:56
阅读 2072·2019-08-30 15:55
阅读 2895·2019-08-30 13:48
阅读 2781·2019-08-29 15:15
阅读 916·2019-08-29 15:14
阅读 2615·2019-08-28 18:26