当前位置: 首页 > wzjs >正文

网站优化如何做深圳福田

网站优化如何做,深圳福田,wordpress wp();,织梦网站首页内容文章目录 Vue简介2.1.1 什么是 vue2.1.2 vue 原理2.1 vue 特性数据驱动视图双向数据绑定总结 2.2 MVVM2.3 MVVM 的工作原理 2.1.3 vue 的版本 2.2 vue 的基本使用2.2.1 基本使用步骤2.2.2 基本代码与 MVVM 的对应关系 2.3 vue 的调试工具2.3.1安装 vue-devtools 调试工具2.3.2 …

文章目录

    • Vue简介
      • 2.1.1 什么是 vue
      • 2.1.2 vue 原理
        • 2.1 vue 特性
          • 数据驱动视图
          • 双向数据绑定
          • 总结
        • 2.2 MVVM
        • 2.3 MVVM 的工作原理
      • 2.1.3 vue 的版本
    • 2.2 vue 的基本使用
      • 2.2.1 基本使用步骤
      • 2.2.2 基本代码与 MVVM 的对应关系
    • 2.3 vue 的调试工具
      • 2.3.1安装 vue-devtools 调试工具
      • 2.3.2 配置 Chrome 浏览器中的 vue-devtools
      • 2.3.3 使用 vue-devtools 调试 vue 页面

Vue简介

2.1.1 什么是 vue

官方给出的概念:Vue (读音 /vjuː/,类似于 view) 是用于构建用户界面j渐进式框架

  1. 构建用户界面
    • 用 vue 往 html 页面中填充数据,非常的方便
  2. 渐进式: 可以使用核心包开发,可以使用Vue核心包+插件 工程化开发
    在这里插入图片描述
  3. 框架
    • 框架是一套现成的解决方案,程序员只能遵守框架的规范,去编写自己的业务功能!
    • 要学习 vue,就是在学习 vue 框架中规定的用法!
    • vue 的指令、组件(是对 UI 结构的复用)、路由、Vuex(这是状态管理的一个东西)、vue 组件库
    • 只有把上面罗列的内容掌握以后,才有开发 vue 项目的能力!

使用js开发能提高70%的效率。

下面举个例子,我使用三种方式完成下面的页面。
在这里插入图片描述

使用js开发

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>js开发</title></head>
<style>#product-list {display: flex;}.product-item{height: 100px;margin-right: 10px;}
</style><body><div id="product-list"></div><script>// 模拟商品数据(实际开发中通过接口获取)const products = [{ id: 1, name: "商品A", price: 100, image: "image1.jpg" },{ id: 2, name: "商品B", price: 200, image: "image2.jpg" }];// 渲染商品列表function renderProducts() {const productList = document.getElementById('product-list');productList.innerHTML = ''; // 清空旧内容products.forEach(product => {const productDiv = document.createElement('div');productDiv.className = 'product-item';productDiv.innerHTML = `<img src="${product.image}" alt="${product.name}"><h3>${product.name}</h3><p>价格: ¥${product.price}</p><button onclick="addToCart(${product.id})">加入购物车</button>`;productList.appendChild(productDiv);});}// 初始化渲染renderProducts();</script>
</body></html>

使用核心代码库Vue开发

<!DOCTYPE html>
<html><head><script src="https://cdn.jsdelivr.net/npm/vue@2.6.14/dist/vue.js"></script>
</head>
<style>.product-list {display: flex;}.product-item {height: 100px;margin-right: 10px;}
</style><body><div id="app"><div class="product-list"><div class="product-item" v-for="product in products"><img :src="product.image" :alt="product.name"><h3>{{ product.name }}</h3><p>价格: ¥{{ product.price }}</p><button @click="addToCart">加入购物车</button></div></div></div><script>// 根实例new Vue({el: '#app',data: {products: [{ id: 1, name: "商品A", price: 100, image: "image1.jpg" },{ id: 2, name: "商品B", price: 200, image: "image2.jpg" }]},});</script>
</body></html>

使用cli脚手架构建webpack工程开发

<template><div class="product-list"><div class="product-item" v-for="product in products"><img :src="product.image" :alt="product.name"><h3>{{ product.name }}</h3><p>价格: ¥{{ product.price }}</p><button @click="addToCart">加入购物车</button></div></div>
</template><script>
export default {data(){return{ products: [{ id: 1, name: "商品A", price: 100, image: "image1.jpg" },{ id: 2, name: "商品B", price: 200, image: "image2.jpg" }]}}
} 
</script><style lang="less" scoped>.product-list {display: flex;}.product-item {height: 100px;margin-right: 10px;}
</style>

通过对比发现使用核心代码库开发和webpack开发比JavaScript开发代码少了不少。

2.1.2 vue 原理

2.1 vue 特性

为什么上面的Vue代码不用操作DOM元素就可以直接复制呢?

vue 框架的特性,主要体现在如下两方面:
① 数据驱动视图
② 双向数据绑定

数据驱动视图

在使用了 vue 的页面中,vue 会监听数据的变化,从而自动重新渲染页面的结构。示意图如下:

在这里插入图片描述

好处:当页面数据发生变化时,页面会自动重新渲染!
注意:数据驱动视图是单向的数据绑定。

双向数据绑定

在填写表单时,双向数据绑定可以辅助开发者在不操作 DOM 的前提下,自动把用户填写的内容同步到数据源

中。示意图如下:

请添加图片描述

好处:开发者不再需要手动操作 DOM 元素,来获取表单元素最新的值!

总结
  1. 数据驱动视图(单向):

    • 数据的变化会驱动视图自动更新
    • 好处:程序员只管把数据维护好,那么页面结构会被 vue 自动渲染出来!
  2. 双向数据绑定:

在网页中,form 表单负责采集数据,Ajax 负责提交数据

  • js 数据的变化,会被自动渲染到页面上
  • 页面上表单采集的数据发生变化的时候,会被 vue 自动获取到,并更新到 js 数据中

注意:数据驱动视图和双向数据绑定的底层原理是 MVVM(Mode 数据源、View 视图、ViewModel (就是 vue 的实例))

2.2 MVVM

MVVM 是 vue 实现数据驱动视图双向数据绑定的核心原理。MVVM 指的是 Model、View 和 ViewModel,

它把每个 HTML 页面都拆分成了这三个部分,如图所示:

请添加图片描述

在 MVVM 概念中:

  • Model 表示当前页面渲染时所依赖的数据源。(后端返回给前端的值)
  • View 表示当前页面所渲染的 DOM 结构。也就是声明的一些标签(页面标签)
  • ViewModel 表示 vue 的实例,它是 MVVM 的核心。也就是Vue
2.3 MVVM 的工作原理

ViewModel 作为 MVVM 的核心,是它把当前页面的数据源(Model)和页面的结构(View)连接在了一起。

请添加图片描述

当数据源发生变化时,会被 ViewModel 监听到,VM 会根据最新的数据源自动更新页面的结构

当表单元素的值发生变化时,也会被 VM 监听到,VM 会把变化过后最新的值自动同步到 Model 数据源中

2.1.3 vue 的版本

当前,vue 共有 3 个大版本,其中:

  • 1.x 版本的 vue 几乎被淘汰,不再建议学习与使用
  • 2.x 版本的 vue 是目前企业级项目开发中的主流版本 (vue2 在未来会被逐渐淘汰)
  • 3.x 版本的 vue 于 2020-09-19 发布,生态还不完善,尚未在企业级项目开发中普及和推广(vue3 是未来企业级项目开发的趋势)

2.2 vue 的基本使用

2.2.1 基本使用步骤

① 导入 vue.js 的 script 脚本文件
② 在页面中声明一个将要被 vue 所控制的 DOM 区域
③ 创建 vm 实例对象(vue 实例对象)

首先将第二章中资料的lib文件夹放入 新建的day2_code文件夹中,用VsCode打开day2_code文件夹

注意也可以直接引入在线版这样就不用下载了:Vue官网获取在线的vue.js 的 script 脚本文件
在这里插入图片描述

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head><body><!-- 希望 Vue 能够控制下面的这个 div,帮我们在把数据填充到 div 内部 --><div id="app">{{ username }}</div><!-- 1. 导入 Vue 的库文件,在 window 全局就有了 Vue 这个构造函数 --><script src="./lib/vue-2.6.12.js"></script><!-- 2. 创建 Vue 的实例对象 --><script>// 创建 Vue 的实例对象const vm = new Vue({// el 属性是固定的写法,表示当前 vm 实例要控制页面上的哪个区域,接收的值是一个选择器el: '#app',// data 对象就是要渲染到页面上的数据data: {username: 'zhangsan'}})</script>
</body></html>

2.2.2 基本代码与 MVVM 的对应关系

请添加图片描述

2.3 vue 的调试工具

2.3.1安装 vue-devtools 调试工具

vue 官方提供的 vue-devtools 调试工具,能够方便开发者对 vue 项目进行调试与开发。

Chrome 浏览器在线安装 vue-devtools :安装连接

FireFox 浏览器在线安装 vue-devtools :安装连接

2.3.2 配置 Chrome 浏览器中的 vue-devtools

点击 Chrome 浏览器右上角的:按钮,选择更多工具 -> 扩展程序 -> Vue.js devtools 详细信息,并勾选如下的两个选项:

请添加图片描述

2.3.3 使用 vue-devtools 调试 vue 页面

在浏览器中访问一个使用了 vue 的页面,打开浏览器的开发者工具(F12键),切换到 Vue 面板,即可使用 vue-devtools

调试当前的页面。 点击那个🖊(笔)的图标进行修改

请添加图片描述


文章转载自:

http://fNFv8bOu.mrcpy.cn
http://bU1qbxLu.mrcpy.cn
http://IWtg0sMm.mrcpy.cn
http://9GohKZur.mrcpy.cn
http://zqyl3azs.mrcpy.cn
http://qsnWgc1t.mrcpy.cn
http://NPk0aBij.mrcpy.cn
http://I18h75oW.mrcpy.cn
http://1KtIKW3o.mrcpy.cn
http://tOWpjyAS.mrcpy.cn
http://uzEHEKFw.mrcpy.cn
http://lLIq8g9D.mrcpy.cn
http://aJzN0Vti.mrcpy.cn
http://4Hu0j77N.mrcpy.cn
http://r5cqOGDQ.mrcpy.cn
http://8ACNww3c.mrcpy.cn
http://IRieovSy.mrcpy.cn
http://Y4pnGOo5.mrcpy.cn
http://pfPhLIYM.mrcpy.cn
http://NQbdZR54.mrcpy.cn
http://mAT5T14P.mrcpy.cn
http://73YcvX7Y.mrcpy.cn
http://IRoXlHRV.mrcpy.cn
http://FUqWSnFP.mrcpy.cn
http://g5uysJg0.mrcpy.cn
http://hodVDjse.mrcpy.cn
http://lMZZSAg5.mrcpy.cn
http://0yaS2Ns7.mrcpy.cn
http://oG8NkoNg.mrcpy.cn
http://jQz73GHX.mrcpy.cn
http://www.dtcms.com/wzjs/702863.html

相关文章:

  • 时装网站建设的背景青海省住房和城乡建设部网站
  • 网站配置全球贸易平台
  • 用易语言做攻击网站软件下载汽配网站建设成本
  • 小说网站开发思路抖音代运营培训
  • 辽宁做网站免费高清无专码区直接看
  • 深圳网站设计收费wordpress theme ide
  • 网易网站开发淘宝客手机网站搭建
  • 挖掘爱站网什么是二级网站推广
  • 成都建站模板制作网站的工作流程
  • 怎么把自己的网站做自适应网站网站服务器修改登录密码
  • 开发公司交钥匙流程官网seo
  • 八里庄街道网站建设网站设计时多页面切换时什么控件
  • 东莞门户网站建设报价表青岛网站设计公司在哪找
  • 网站开发都用php网站设计和网页设计
  • 我做网站价格一个网站可以做多少个小程序
  • 住房和建设厅官方网站怎么才能在百度搜到自己的网站
  • 广东粤建设计院网站seo宣传网站
  • 网站开发技术写什么内容北京最大的火车站
  • 政务服务网站建设性建议seo网站推广全程实例
  • 西宁网站建设优化四川省城乡和住房建设厅网站首页
  • 在东莞找工作上哪个网站汕头老城图片
  • 展示营销型网站做app网站制作
  • 建设解锁卡网站首页润滑油网站建设
  • 建设网站公开教学视频下载响应式网站开发周期
  • 网站建设公司哪家好 要上磐石网络上传网站安装教程视频教程
  • 百度上做网站需要钱吗网站漂浮二维码
  • 做网站用的插件游戏网站建设方案
  • 深圳市信任网站关于网站建设的问卷分析
  • 湘潭网站建设湘潭振企专业小白怎么制作微信小程序
  • 找家里做的工作上哪个网站嘉兴做微网站