zoukankan      html  css  js  c++  java
  • django项目实战

    0x00 项目环境说明

    前端方向:

    nvm:用来管理node.js的工具。
    node.js:自带有npm包管理工具。
    npm:类似于Python中的pip。可以非常方便的管理一些前端开发的包。
    gulp:用来自动化开发流程。比如sass转css,css和js压缩等。

    后端方向:

    Python 3.6:开发语言。
    Django 2.0:开发框架。
    MySQL 5.7:数据库。

    0x01 前端环境配置

    前端开发环境配置:

    nvm安装:

    nvm(Node Version Manager)是一个用来管理node版本的工具。我们之所以需要使用node,是因为我们需要使用node中的npm(Node Package Manager),使用npm的目的是为了能够方便的管理一些前端开发的包!nvm的安装非常简单,步骤如下:

    到这个链接下载nvm的安装包:https://github.com/coreybutler/nvm-windows/releases。
    然后点击一顿下一步,安装即可!
    安装完成后,还需要配置环境变量。在我的电脑->属性->高级系统设置->环境变量->系统环境变量->Path下新建一个,把nvm所处的路径填入进去即可!
    打开cmd,然后输入nvm,如果没有提示没有找不到这个命令。说明已经安装成功!
    Mac或者Linux安装nvm请看这里:https://github.com/creationix/nvm。也要记得配置环境变量。
    nvm常用命令:

    nvm install node:安装最新版的node.js。nvm i == nvm install。
    nvm install [version]:安装指定版本的node.js 。
    nvm use [version]:使用某个版本的node。
    nvm list:列出当前安装了哪些版本的node。
    nvm uninstall [version]:卸载指定版本的node。
    nvm node_mirror [url]:设置nvm的镜像。
    nvm npm_mirror [url]:设置npm的镜像。

    node安装:

    安装完nvm后,我们就可以通过nvm来安装node了。这里我们安装6.4.0版本的的node.js就可以。因为最新版的node.js的npm是5.0的,上面还有很多坑。安装命令如下:

    nvm install 6.4.0
    如果你的网络够快,那以上命令在稍等片刻之后会安装成功。如果你的网速很慢,那以上命令可能会发生超时。因为node的服务器地址是https://nodejs.org/dist/,这个域名的服务器是在国外。因此会比较慢。因此我们可以设置一下nvm的源。

    nvm node_mirror https://npm.taobao.org/mirrors/node/
    nvm npm_mirror https://npm.taobao.org/mirrors/npm/

    npm:

    npm(Node Package Manager)在安装node的时候就会自动的安装了。当时前提条件是你需要设置当前的node的版本:nvm use 6.4.0。然后就可以使用npm了.
    关于npm常用命令以及用法,请看下文。

    安装包:

    安装包分为全局安装和本地安装。全局安装是安装在当前node环境中,在可以在cmd中当作命令使用。而本地安装是安装在当前项目中,只有当前这个项目能使用,并且可以通过require引用。安装的方式只有-g参数的区别:

    npm install express # 本地安装
    npm install express -g # 全局安装

    本地安装

    将安装包放在./node_modules下(运行 npm 命令时所在的目录),如果没有node_modules目录,会在当前执行npm命令的目录下生成node_modules目录。
    可以通过require()来引入本地安装的包。

    全局安装

    将安装包放在/usr/local下或者你node的安装目录。
    可以直接在命令行里使用。

    卸载包:

    npm uninstall [package]

    更新包:

    npm update [package]

    搜索包:

    npm search [package]

    使用淘宝镜像:

    npm install -g cnpm --registry=https://registry.npm.taobao.org 那么以后就可以使用cnpm来安装包了!

    前端项目搭建

    前端我们使用gulp来自动化开发流程。配置好gulp后,可以自动给我们处理好一些工作。比如写完css后,要压缩成.min.css,写完js后,要做混淆和压缩,图片压缩等。这些工作都可以让gulp帮我们完成。

    安装gulp:

    1. 创建本地包管理环境:

    使用npm init命令在本地生成一个package.json文件,package.json是用来记录你当前这个项目依赖了哪些包,以后别人拿到你这个项目后,不需要你的node_modules文件夹(因为node_moduels中的包实在太庞大了)。只需要执行npm install命令,即会自动安装package.json下devDependencies中指定的依赖包。

    2. 安装gulp:

    gulp的安装非常简单,只要使用npm命令安装即可。但是因为gulp需要作为命令行的方式运行,因此需要在安装在系统级别的目录中。

    npm install gulp -g
    

    因为在本地需要使用require的方式gulp。因此也需要在本地安装一份:

    npm install gulp --save-dev
    

    以上的--save-dev是将安装的包的添加到package.json下的devDependencies依赖中。以后通过npm install即可自动安装。devDependencies这个是用来记录开发环境下使用的包,如果想要记录生产环境下使用的包,那么在安装包的时候使用npm install xx --save就会记录到package.json下的dependencies中,dependencies是专门用来记录生产环境下的依赖包的!

    3. 创建gulp任务:

    要使用gulp来流程化我们的开发工作。首先需要在项目的根目录下创建一个gulpfile.js文件。然后在gulpfile.js中填入以下代码:

    var gulp = require("gulp")
    
    gulp.task("greet",function () {
        console.log('hello world');
    });
    

    这里对代码进行一一解释:

    通过require语句引用已经安装的第三方依赖包。这个require只能是引用当前项目的,不能引用全局下的。require语法是node.js独有的,只能在node.js环境下使用。

    gulp.task是用来创建一个任务。gulp.task的第一个参数是命令的名字,第二个参数是一个函数,就是执行这个命令的时候会做什么事情,都是写在这个里面的。

    写完以上代码后,以后如果想要执行greet命令,那么只需要进入到项目所在的路径,然后终端使用gulp greet即可执行。

    4. 创建处理css文件的任务:

    gulp只是提供一个框架给我们。如果我们想要实现一些更加复杂的功能,比如css压缩,那么我们还需要安装一下gulp-cssnano插件。gulp相关的插件安装也是通过npm命令安装,安装方式跟其他包是一模一样的(gulp插件本身就是一个普通的包)。
    对css文件的处理,需要做的事情就是压缩,然后再将压缩后的文件放到指定目录下(不要和原来css文件重合了)!这里我们使用gulp-cssnano来处理这个工作:

    npm install gulp-cssnano --save-dev
    

    然后在gulpfile.js中写入以下代码:

    var gulp = require("gulp")
    var cssnano = require("gulp-cssnano")
    
    // 定义一个处理css文件改动的任务
    gulp.task("css",function () {
        gulp.src("./css/*.css")
        .pipe(cssnano())
        .pipe(gulp.dest("./css/dist/"))
    });
    

    以上对代码进行详细解释:

    gulp.task:创建一个css处理的任务。
    gulp.src:找到当前css目录下所有以.css结尾的css文件。
    pipe:管道方法。将上一个方法的返回结果传给另外一个处理器。比如以上的cssnano。
    gulp.dest:将处理完后的文件,放到指定的目录下。不要放在和原文件相同的目录,以免产生冲突,也不方便管理。

    5. 修改文件名:

    像以上任务,压缩完css文件后,最好是给他添加一个.min.css的后缀,这样一眼就能知道这个是经过压缩后的文件。这时候我们就需要使用gulp-rename来修改了。当然首先也需要安装npm install gulp-rename --save-dev。示例代码如下:

    var gulp = require("gulp")
    var cssnano = require("gulp-cssnano")
    var rename = require("gulp-rename")
    gulp.task("css",function () {
        gulp.src("./css/*.css")
        .pipe(cssnano())
        .pipe(rename({"suffix":".min"}))
        .pipe(gulp.dest("./css/dist/"))
    });
    

    在上述代码中,我们增加了一行.pipe(rename({"suffix":".min"})),这个我们就是使用rename方法,并且传递一个对象参数,指定修改名字的规则为添加一个.min后缀名。这个gulp-rename还有其他的指定文件名的方式,比如可以在文件名前加个前缀等。更多的教程可以看这个:https://www.npmjs.com/package/gulp-rename。

    6. 创建处理js文件的任务:

    处理js文件,我们需要使用到gulp-uglify插件。安装命令如下:

    npm install gulp-uglify --save-dev
    安装完后,我们就可以对js文件进行处理了。示例代码如下:

    var gulp = require("gulp")
    var rename = require("gulp-rename")
    var uglify = require('gulp-uglify');
    gulp.task('script',function(){
        gulp.src(path.js + '*.js')
        .pipe(uglify())
        .pipe(rename({suffix:'.min'}))
        .pipe(gulp.dest('js/'));
    });
    

    这里就是增加了一个.pipe(uglify())的处理,对js文件进行压缩和丑化(修改变量名)等处理。更多关于gulp-uglify的教程。请看:https://github.com/mishoo/UglifyJS2#minify-options。

    7. 合并多个文件:

    在网页开发中,为了加快网页的渲染速度,有时候我们会将多个文件压缩成一个文件,从而减少请求的次数。要拼接文件,我们需要用到gulp-concat插件。安装命令如下:

    npm install gulp-concat --save-dev
    比如我们现在有一个nav.js文件用来控制导航条的。有一个index.js文件用来控制首页整体内容的。那么我们可以使用以下代码将这两个文件合并成一个文件:

    var gulp = require('gulp');
    var concat = require('gulp-concat');
    var uglify = require('gulp-uglify');
    gulp.task('vendorjs',function(){
        gulp.src([
            './js/nav.js',
            './js/index.js'
        ])
        .pipe(concat('index.min.js'))
        .pipe(uglify())
        .pipe(gulp.dest('dist/js/'));
    });
    

    8. 压缩图片:

    图片是限制网站加载速度的一个主要原因。图片越大,从网站上下载所花费的时间越长。因此对于一些图片,我们可以采取无损压缩,即在不改变图片质量的基础之上进行压缩。在gulp中我们可以通过gulp-imagemin来帮我们实现。安装命令如下:

    npm install gulp-imagemin --save-dev
    压缩图片也是一个比较大的工作量,对于一些已经压缩过的图片,我们就没必要再重复压缩了。这时候我们可以使用gulp-cache来缓存那些压缩过的图片。安装命令如下:

    npm install gulp-cache --save-dev
    两个插件结合使用的代码如下:

    var imagemin = require('gulp-imagemin');
    var cache = require('gulp-cache');
    gulp.task('image',function(){
        gulp.src("./images/*.*")
        .pipe(cache(imagemin()))
        .pipe(gulp.dest('dist/images/'));
    });
    

    9. 检测代码修改,自动刷新浏览器:

    以上所有的任务,我们都是需要手动的在终端去执行。这样很不方便我们开发。最好的方式就是我修改了代码后,gulp会自动的执行相应的任务。这个工作我们可以使用gulp内置的watch方法帮我们完成:

    var gulp = require("gulp")
    var cssnano = require("gulp-cssnano")
    var rename = require("gulp-rename")
    
    // 定义一个处理css文件改动的任务
    gulp.task("css",function () {
        gulp.src("./css/*.css")
        .pipe(cssnano())
        .pipe(rename({"suffix":".min"}))
        .pipe(gulp.dest("./css/dist/"))
        .pipe(connect.reload())
    });
    
    // 定义一个监听的任务
    gulp.task("watch",function () {
        // 监听所有的css文件,然后执行css这个任务
        gulp.watch("./css/*.css",['css'])
    });
    

    以后只要在终端执行gulp watch命令即可自动监听所有的css文件,然后自动执行css的任务,完成相应的工作。

    10. 更改文件后,自动刷新浏览器:

    以上我们实现了更改一些css文件后,可以自动执行处理css的任务。但是我们还是需要手动的去刷新浏览器,才能看到修改后的效果。有什么办法能在修改完代码后,自动的刷新浏览器呢。答案是使用browser-sync。browser-sync安装的命令如下:

    npm install browser-sync --save-dev
    

    browser-sync使用的示例代码如下:

    var gulp = require("gulp")
    var cssnano = require("gulp-cssnano")
    var rename = require("gulp-rename")
    var bs = require("browser-sync").create()
    
    gulp.task("bs",function () {
        bs.init({
            'server': {
                'baseDir': './'
            }
        });
    });
    
    // 定义一个处理css文件改动的任务
    gulp.task("css",function () {
        gulp.src("./css/*.css")
        .pipe(cssnano())
        .pipe(rename({"suffix":".min"}))
        .pipe(gulp.dest("./css/dist/"))
        .pipe(bs.stream())
    });
    
    // 定义一个监听的任务
    gulp.task("watch",function () {
        gulp.watch("./css/*.css",['css'])
    });
    
    // 执行gulp server开启服务器
    gulp.task("server",['bs','watch'])
    

    以上我们创建了一个bs的任务,这个任务会开启一个3000端口,以后我们在访问html页面的时候,就需要通过http://127.0.0.1:3000的方式来访问了。然后接下来我们还定义了一个server任务。这个任务会去执行bs和watch任务,只要修改了css文件,那么就会执行css的任务,然后就会自动刷新浏览器。
    browser-sync更多的教程请参考:http://www.browsersync.cn/docs/gulp/。

  • 相关阅读:
    Java基础知识(一)环境变量的设置、变量与常量、自动类型转换、自增长、赋值运算符
    ModelState
    DOM
    正则表达式常见形式
    通过JS设置一个元素的文本
    JS(三) 原型对象与原型链
    JS(二)call方法和apply方法
    第四周学习进度表
    敏捷开发方法综述
    数组02
  • 原文地址:https://www.cnblogs.com/wangtanzhi/p/12520709.html
Copyright © 2011-2022 走看看