Django+Vue开发生鲜电商平台之4.Restful API和Vue介绍

简介: 近年来,随着多种平台类型(PC端、Android端、Mac端、iPhone端、Pad端等)的出现和普及,前后端分离变得更加重要和流行,显然,其是具有一定的适应性的。

一、Restful API介绍

1.前后端分离优缺点

近年来,随着多种平台类型(PC端、Android端、Mac端、iPhone端、Pad端等)的出现和普及,前后端分离变得更加重要和流行,显然,其是具有一定的适应性的。

前后端分离的原因如下:

  • PC、APP、Pad等多端适应的要求
    近几年随着移动端的普及,需要对其进行适应,运用传统的方式只适用于PC端,需要前后端分离实现对移动端的适应。
  • SPA开发模式逐渐流行
    SPA模式即单页Web应用模式,对单页应用来说模块化的开发和设计显得相当重要。
  • 前后端开发职责分工不清
    在编写模板时,会面临着是由前端还是后端开发的问题,如果由前端人员来开发就必须了解后端语言,如果由后端人员来写就必须了解前端知识。
  • 开发效率低下,前后端互相等待
    之前的模式是前端需要等待后端开发完成后才能开发,或者后端等待前端,造成效率低下。
  • 前端被动配合后端,能力受限
    由于很多业务逻辑是在是在模板语法中实现,前端开发者只是单纯地给后端提供前端网页文件,开发能力受到限制。
  • 后台开发语言和模板高度耦合,导致开发语言依赖严重
    由于后台采用单一的开发语言进行开发,导致了高耦合,后端语言的切换成本很高。

但是前后端分离也存在一些局限性:

  • 前后端学习门槛增加
    由于开发模式的改变,导致前后端开发者均不能再像之前那样只是负责自己的那一块即可,为了前后端配合,需要学习更多的技术和方法。
  • 数据依赖导致文档重要性增加
    后端把数据交给前端时,如果没有文档,前端就可能会出现很严重的问题,还要保证文档的及时更新和准确。
  • SEO的难度增大
    现在很多页面中只是HTML框架,并没有数据,这虽然在很大程度上放置了爬虫,但同时也对搜索引擎的索索造成了很大影响。
  • 后端开发模式迁移增加成本
    不同的开发语言对应的模板语法不同,因此在进行迁移时也会面临很大的成本。

2.Restful API简介

REST全称Representational State Transfer,中文为表征性状态转移,而RESTful API就是REST风格的API,即rest是一种架构风格,与开发语言无关,跟平台无关,采用HTTP做传输协议。restful api目前是前后端分离的最佳实践,它不是一种框架,而只是为前后端分离提供了一种标准、规范,具有以下特点:

(1)轻量,直接通过http协议,而不需要额外的协议,包括post、get、put、delete操作;

(2)面向资源,可读性好、一目了然,具有自解释性;

(3)数据描述简单,一般通过json或者xml进行数据通信。

Restful API充分利用HTTP状态码和请求方法来完成其标准设计,大量运用已有规范实现新的标准,而Django Restful framework是完全按照Restful API标准实现的。

二、Vue的基本介绍

1.前端重要概念

(1)前端工程化

工程化在后端开发中很常见,对于前端开发,工程化也逐步完善成熟,Node.js和webpack的出现推进了前端工程化的发展。

(2)数据双向绑定

数据和页面的双向绑定,修改任何一个,另一个都会同步变化,MVVM也是这个概念,Angular、Vue都实现了数据双向绑定。

(3)组件化开发

做一个组件,只需要导入和组件相关的元素即可,从而加大了项目的纯度。

(4)webpack

Webpack是一个前端资源加载、打包工具。它将根据模块间的依赖关系进行静态分析,然后根据指定的规则生成相应的静态资源。其实现了代码转换,将开发文件转化为基础的HTML、CSS、JavaScript文件等功能。

2.Vue重要概念

(1)Vue全家桶

Vue

Vue.js是一套构建用户界面的渐进式框架,只关注视图层,采用自底向上增量开发的设计,其目标是通过尽可能简单的API实现响应的数据绑定和组合的视图组件。

Vuex:

用于Vue组件之间的通信。

Vue-Router:

Vue组件之间的跳转,将路径和组件关联。

axios:

在Vue中发送Ajax请求。

(2)ES6和babel

ES6:

ES6,全称ECMAScript 6.0,是JavaScript的一个新版本标准,主要是为了解决ES5的先天不足。

Babel:

是一个转换器,将ES6语法转化成ES5语法,以兼容浏览器。

三、Vue项目结构介绍

一个典型的Vue项目文件结构类似如下:

├─mock                                                 
│  └─mock                                              
└─src                                                  
    ├─api                                              
    ├─axios                                            
    ├─components                                       
    │  ├─common                                        
    │  │  ├─associateFile                              
    │  │  ├─cloud-cooperation                          
    │  │  ├─contextmenu                                
    │  │  ├─control                                    
    │  │  ├─current-loc                                
    │  │  ├─drag                                       
    │  │  ├─layout                                     
    │  │  ├─list-nav                                   
    │  │  ├─list-sort                                  
    │  │  │  └─images                                  
    │  │  ├─loading                                    
    │  │  ├─loading2                                   
    │  │  ├─menu                                       
    │  │  ├─nodata                                     
    │  │  ├─page                                       
    │  │  ├─price-range                                
    │  │  │  └─images                                  
    │  │  ├─product-list                               
    │  │  │  └─images                                  
    │  │  ├─result-list                                
    │  │  └─tag                                        
    │  └─heighchart                                    
    │      ├─bar                                       
    │      │  └─line-bar                               
    │      └─circle                                    
    │          └─circle                                
    ├─router                                           
    ├─static                                           
    │  ├─images                                        
    │  │  ├─footer                                     
    │  │  ├─head                                       
    │  │  ├─indexNew                                   
    │  │  ├─login                                      
    │  │  ├─loginHead                                  
    │  │  ├─new                                        
    │  │  ├─register                                   
    │  │  ├─seriesList                                 
    │  │  └─shopHead                                   
    │  ├─js                                            
    │  └─vendors                                       
    │      └─iview                                     
    │          └─dist                                  
    │              └─styles                            
    │                  └─fonts                         
    ├─store                                            
    ├─styles                                           
    │  └─fonts                                         
    └─views                                            
        ├─app                                          
        ├─cart                                         
        │  └─images                                    
        ├─footer                                       
        │  └─images                                    
        ├─head                                         
        ├─home                                         
        ├─index                                        
        ├─list                                         
        │  ├─current-loc                               
        │  ├─list-nav                                  
        │  ├─list-sort                                 
        │  │  └─images                                 
        │  ├─page                                      
        │  ├─price-range                               
        │  │  └─images                                 
        │  └─product-list                              
        │      └─images                                
        ├─login                                        
        ├─loginHead                                    
        ├─member                                       
        ├─productDetail                                
        │  ├─current-loc                               
        │  └─images                                    
        │      └─images                                
        └─register                                     

其中,src是项目源码,包括:

  • api
    请求网络的API通过此目录实现。
  • axios
    全局拦截等全局设置。
  • components
    项目组件。
  • router
    Vue-Router配置。
  • static
    全局静态资源文件。
  • store
    Vuex存放目录。
  • style
    静态CSS样式。
  • views

所有组件,包括Header、轮播图、新品、导航栏、商品展示、分页、商品详情、个人中心等众多组件,在项目代码中体现为app(入口组件)、cart(购物车组件)、footer(底部组件)、header(顶部组件)、home(主内容组件)、index(首页组件)、list(列表页组件)、login(登录组件)、loginHead(登录页头部组件)、member(个人中心组件)、productDetail(商品详情组件)、register(注册组件)。

本项目的前端部分还包括其他文件,具体目录结构如下:

2345_image_file_copy_1.jpg

前端项目收入整个项目的fresh_online目录下,便于统一管理。

需要安装前端项目的依赖包,直接在fresh_online目录下执行cnpm install并等待安装结束即可,如果目录下生成node_modules目录并且打印出

√ All packages installed (841 packages installed from npm registry, used 38s(network 35s), speed 556.67kB/s, json 731(1.81MB) , tarball 17.06MB)

则安装成功。

相关文章
|
1月前
|
JavaScript API
vue中api统一管理
【10月更文挑战第4天】
|
9天前
|
设计模式 前端开发 数据库
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第27天】本文介绍了Django框架在Python Web开发中的应用,涵盖了Django与Flask等框架的比较、项目结构、模型、视图、模板和URL配置等内容,并展示了实际代码示例,帮助读者快速掌握Django全栈开发的核心技术。
87 44
|
3天前
|
XML JSON API
【PHP开发专栏】PHP RESTful API设计与开发
随着互联网技术的发展,前后端分离成为Web开发的主流模式。本文介绍RESTful API的基本概念、设计原则及在PHP中的实现方法。RESTful API是一种轻量级、无状态的接口设计风格,通过HTTP方法(GET、POST、PUT、DELETE)操作资源,使用JSON或XML格式传输数据。在PHP中,通过定义路由、创建控制器、处理HTTP请求和响应等步骤实现RESTful API,并强调了安全性的重要性。
10 2
|
27天前
|
IDE 关系型数据库 MySQL
Django学习一:创建Django框架,介绍Django的项目结构和开发逻辑。创建应用,编写主包和应用中的helloworld
这篇文章是关于如何创建一个Django框架,介绍Django的项目结构和开发逻辑,并指导如何创建应用和编写“Hello, World!”程序的教程。
34 3
Django学习一:创建Django框架,介绍Django的项目结构和开发逻辑。创建应用,编写主包和应用中的helloworld
|
10天前
|
前端开发 关系型数据库 API
深入浅出后端开发——从零到一构建RESTful API
本文旨在为初学者提供一个关于后端开发的全面指南,特别是如何从零开始构建一个RESTful API。我们将探讨后端开发的基本概念、所需技术栈、以及通过实际案例展示如何设计和实现一个简单的RESTful API。无论你是完全的新手还是有一定编程基础的开发者,这篇文章都将为你提供实用的知识和技巧,帮助你在后端开发的道路上迈出坚实的一步。
|
10天前
|
安全 数据库 开发者
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第26天】本文详细介绍了如何在Django框架下进行全栈开发,包括环境安装与配置、创建项目和应用、定义模型类、运行数据库迁移、创建视图和URL映射、编写模板以及启动开发服务器等步骤,并通过示例代码展示了具体实现过程。
26 2
|
15天前
|
存储 XML API
探索后端开发中的RESTful API设计哲学
【10月更文挑战第21天】在数字化时代,后端开发是构建强大、可靠和可扩展应用程序的基石。本文将深入探讨RESTful API的设计原则,并展示如何通过这些原则来提升API的质量和性能。我们将从基础概念出发,逐步深入到实际案例分析,揭示高效API设计的秘诀。无论你是初学者还是有经验的开发者,这篇文章都将为你提供宝贵的见解和实用的技巧,帮助你在后端开发的道路上更进一步。
|
1月前
|
存储 API 数据库
深入浅出后端开发:从零到一搭建RESTful API
在数字化的浪潮中,后端开发如同一座桥梁,连接着用户界面与数据存储。本文将引导你理解后端开发的核心概念,并通过实践案例,展示如何从零开始构建一个RESTful API。我们将探索设计原则、选择合适的编程语言和框架、数据库交互以及API测试等方面。无论你是初学者还是希望巩固知识的开发者,这篇文章都将为你提供一条清晰的学习路径。
|
1月前
|
存储 JSON JavaScript
探索后端开发:从零构建简易RESTful API
【9月更文挑战第35天】在数字时代的浪潮中,了解如何搭建一个后端服务变得至关重要。本文将通过构建一个简易的RESTful API来揭开后端开发的神秘面纱。我们将使用Node.js和Express框架,逐步引导你理解并实践API的设计、实现与测试过程。无论你是编程新手还是希望扩展技能边界的开发者,这篇文章都将为你提供一次深入浅出的学习旅程。
|
2月前
|
前端开发 API 开发者
探索后端开发中的RESTful API设计原则
【9月更文挑战第21天】在数字化时代的浪潮中,后端开发扮演着至关重要的角色。本文将深入探讨RESTful API的设计原则,旨在为开发者提供一套清晰、高效的指导方针。我们将从资源的命名与表述开始,逐步引导您理解如何通过统一接口和状态码来构建可扩展且易于维护的API。文章不仅涵盖理论知识,还将通过实际代码示例,展示如何将这些原则应用于日常开发实践中。无论您是初学者还是经验丰富的开发者,这篇文章都将为您的后端开发之旅增添宝贵的知识财富。
下一篇
无影云桌面