NODEJS + VUE

简单回顾一下之前做的项目:

一、什么是nodejs?

脚本语言需要一个解析器才能运行,JavaScript是脚本语言,在不同的位置有不一样的解析器,如写入html的js语言,浏览器是它的解析器角色。而对于需要独立运行的JS,nodejs就是一个解析器。

每一种解析器都是一个运行环境,不但允许js定义各种数据结构,进行各种计算,还允许js使用允许环境提供的内置对象和方法做一些事情。如运行在浏览器中的js的用途是操作DOM,浏览器就提供了document之类的内置对象。而运行在nodejs中的js的用途是操作磁盘文件或搭建http服务器,nodejs就相应提供了fs,http等内置对象。

这边nodejs主要是为了接收vue不同组件传递过来的数据,进行判断处理或者传递到服务器,然后再将服务器返回的数据传回vue前端。
同时nodejs的config文件夹里面还可以进行开发生产环境的区分。

二、VUE简介

VUE作者叫尤雨溪,一个从本科读艺术史到硕士读美术设计和技术专业,跨行开发前端框架的大佬。

Vue.js 是一套构建用户界面的渐进式(Progressive framework)框架,是MVVM开发模式的实现者。

VVM源自于经典的 MVC(Model-View-Controller)模式。MVVM的核心是ViewModel层,负责转换 Model中的数据对象,来让数据变得更容易管理和使用,其作用如下:

1、该层向上与视图层进行双向数据绑定
2、向下与Model层通过接口请求进行数据交互

View是视图层,也就是用户界面。前端主要由HTML和css来构建,为了更方便地展现ViewModel或者Model层的数据,已经产生了各种各样的前后端模板语言,比如 FreeMarker、Thymeleaf 等等,各大 MVVM框架如Vue.js,AngularJS,EJS等也都有自己用来构建用户界面的内置模板语言。

Model是指数据模型,泛指后端进行的各种业务逻辑处理和数据操控,主要围绕数据库系统展开。这里的难点主要在于需要和前端约定统一的接口规则。

ViewModel是由前端开发人员组织生成和维护的视图数据层。在这一层,前端开发者对从后端获取的Model数据进行转换处理,做二次封装,以生成符合View层使用预期的视图数据模型。

换言之,VM的实现原理:

view model中内置了一个观察者,这个观察者观察两个维度
​ 1) 观察视图的变化: 当视图变了,就通知数据进行变化
​ 2) 观察数据的变化: 当数据变了,就通知视图进行变化

​ ------ MVVM通过VM实现了双向数据绑定

VUE的双向绑定和生命周期 的概念是比较重要的。

vue-cli官方提供的一个脚手架,用于快速生成一个vue的项目模板。

ElementUI是比较流行的开源vue组件代码。

二、大概项目逻辑

①首先在front文件夹找到index.html文件,看到它绑定了唯一的容器的id="app"

②再找到入口文件main.js,去生成vue,并且绑定容器app

③编写router.js,默认是 / ,将它redirect到/login ;而/login注册了一个组件Login

④我将login.vue放在了models文件夹下,这个组件渲染出来就是登录页面。其中当点击登录的button是,会触发@click事件,进而将username和pwd通过axios.post传到Node后端。

⑤找到后端的router.js文件,通过nodejs后端的路由。找到相应的处理js。可以封装一下到service,将数据post到服务器进行验证,等待返回的token。若状态是200则继续进行后续内容,否则返回错误的ctx给前端。

⑥我们其他子组件的路由,是可以根据服务器返回的内容,进行动态的注册子组件的。这样就可以实现通过操控数据的数据字段,来决定网页端的页面显示与否。

⑦具体子组件的内容,再进行另外设计。

相关推荐
GISer_Jing1 分钟前
Vue3状态管理——Pinia
前端·javascript·vue.js
好开心3316 分钟前
axios的使用
开发语言·前端·javascript·前端框架·html
Domain-zhuo25 分钟前
Git常用命令
前端·git·gitee·github·gitea·gitcode
菜根Sec1 小时前
XSS跨站脚本攻击漏洞练习
前端·xss
web150854159351 小时前
vue 集成 webrtc-streamer 播放视频流 - 解决阿里云内外网访问视频流问题
vue.js·阿里云·webrtc
m0_748257181 小时前
Spring Boot FileUpLoad and Interceptor(文件上传和拦截器,Web入门知识)
前端·spring boot·后端
桃园码工1 小时前
15_HTML5 表单属性 --[HTML5 API 学习之旅]
前端·html5·表单属性
百万蹄蹄向前冲2 小时前
2024不一样的VUE3期末考查
前端·javascript·程序员
Anlici2 小时前
three.js建立3D模型展示地球+高亮
前端·数据可视化·canvas
轻口味2 小时前
【每日学点鸿蒙知识】AVCodec、SmartPerf工具、web组件加载、监听键盘的显示隐藏、Asset Store Kit
前端·华为·harmonyos