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

Vue学习第二天

  • vue单文件方式 xxx.vue
  • 1:准备好配置文件 package.json(包描述文件&& 封装命令npm run dev) + webpack.config.js文件(打包的配置文件)
  • 2:创建index.html(单页应用的页)
  • 3:创建main.js(入口文件)
  • 4:引入vue和相关的文件xxx.vue
  • 5:new Vue(options)
  • 6:options(选项):

    • data
    • methods
    • components(组件内声明子组件)
    • props
  • 7:实例:

    • 在组件内(xxx.vue)中的this
    • new Vue()
    • 事件

      • this.$on(事件名,回调函数(参数))
      • this.$emit(事件名,数据)
      • this.$once(事件名,回调函数(参数)) 就触发一次
      • this.$off(事件名); 取消事件
  • 8:全局

    • Vue.component('组件名',组件对象) 在哪里都可以使用
  • 9: 组件传值

    • 父传子: 属性作为参数

      • 常量 title="xxx" 子组件声明接收参数 props:['xxx']
      • 变量 :title="num" 子组件声明接收参数 props:['xxx']
    • 子传父: vuebus(只能是同一辆车)

      • 先停车到父组件,On一下
      • 再开车到子组件,如果需要的话,emit一下,触发上述时间的回调函数

今日重点

  • vue组件的使用
  • 组件间通信
  • vue-router使用
  • axios

过滤器

  • content | 过滤器,vue中没有提供相关的内置过滤器,可以自定义过滤器
  • 组件内的过滤器 + 全局过滤器

    • 组件内过滤器就是options中的一个filters的属性(一个对象)

      • 多个key就是不同过滤器名,多个value就是与key对应的过滤方式函数体
全局过滤器- `Vue.filter(名,fn)`
组件内的过滤器 - `filters:{test(option){ return option.split()}}`
  • 输入的内容帮我做一个反转
  • 例子:父已托我帮你办点事
  • 总结

    • 全局 :范围大,如果出现同名时,权利小
    • 组件内: 如果出现同名时,权利大,范围小

获取DOM元素

  • 救命稻草, 前端框架就是为了减少DOM操作,但是特定情况下,也给你留了后门
  • 在指定的元素上,添加ref="名称A"
  • 在获取的地方加入 this.$refs.名称A

    • 如果ref放在了原生DOM元素上,获取的数据就是原生DOM对象

      • 可以直接操作
    • 如果ref放在了组件对象上,获取的就是组件对象

      • 1:获取到DOM对象,通过this.$refs.sub.$el,进行操作
    • 对应的事件

      • created 完成了数据的初始化,此时还未生成DOM,无法操作DOM
      • mounted 将数据已经装载到了DOM之上,可以操作DOM

mint-ui

  • 组件库
  • 饿了么出品,element-ui 在PC端使用的
  • 移动端版本 mint-ui
  • https://mint-ui.github.io/#!/...
  • 注意:

    • 如果是全部安装的方式

      • 1:在template中可以直接使用组件标签
      • 2:在script中必须要声明,也就是引入组件对象(按需加载)

wappalyzer

  • 获取到当前网站的使用的技术
  • https://wappalyzer.com/download

vue-router

  • 前端路由 核心就是锚点值的改变,根据不同的值,渲染指定DOM位置的不同数据
  • ui-router:锚点值改变,如何获取模板?ajax、
  • vue中,模板数据不是通过ajax请求来,而是调用函数获取到模板内容
  • 核心:锚点值改变
  • 以后看到vue开头,就知道必须Vue.use
  • vue的核心插件:

    • vue-router 路由
    • vuex 管理全局共享数据
  • 使用方式

    • 1:下载 npm i vue-router -S
    • 2:在main.js中引入 import VueRouter from 'vue-router';
    • 3:安装插件 Vue.use(VueRouter);
    • 4:创建路由对象并配置路由规则

      • let router = new VueRouter({ routes:[ {path:'/home',component:Home} ] });
    • 5:将其路由对象传递给Vue的实例,options中

      • options中加入 router:router
    • 6:在app.vue中留坑 <router-view></router-view>

命名路由

  • 需求,通过a标签点击,做页面数据的跳转
  • 使用router-link标签

    • 1:去哪里 <router-link to="/beijing">去北京</router-link>
    • 2:去哪里 <router-link :to="{name:'bj'}">去北京</router-link>

      • 更利于维护,如果修改了path,只修改路由配置中的path,该a标签会根据修改后的值生成href属性

参数router-link

  • 在vue-router中,有两大对象被挂载到了实例this
  • $route(只读、具备信息的对象)、$router(具备功能函数)
  • 查询字符串

    • 1:去哪里 <router-link :to="{name:'detail',query:{id:1} } ">xxx</router-link>
    • 2:导航(查询字符串path不用改) { name:'detail' , path:'/detail',组件}
    • 3:去了干嘛,获取路由参数(要注意是query还是params和对应id名)

      • this.$route.query.id
  • path方式

    • 1:去哪里 <router-link :to="{name:'detail',params:{name:1} } ">xxx</router-link>
    • 2:导航(path方式需要在路由规则上加上/:xxx)
    • { name:'detail' , path:'/detail/:name',组件}
    • 3:去了干嘛,获取路由参数(要注意是query还是params和对应name名)

      • this.$route.params.name

编程导航

  • 不能保证用户一定会点击某些按钮
  • 并且当前操作,除了路由跳转以外,还有一些别的附加操作
  • this.$router.go 根据浏览器记录 前进1 后退-1
  • this.$router.push(直接跳转到某个页面显示)

    • push参数: 字符串 /xxx
    • 对象 : {name:'xxx',query:{id:1},params:{name:2} }

复习

  • 过滤器,全局,组件内
  • 获取DOM元素 ,在元素上ref="xxx"
  • 在代码中通过this.$refs.xxx 获取其元素

    • 原生DOM标签获取就是原生DOM对象
    • 如果是组件标签,获取的就是组件对象 $el继续再获取DOM元素
  • 声明周期事件(钩子)回调函数

    • created: 数据的初始化、DOM没有生成
    • mounted: 将数据装载到DOM元素上,此时有DOM
  • 路由

    • window.addEventListener('hashchange',fn);
    • 根据你放<router-view></router-view><div id="xxx"></div> 作为一个DOM上的标识
    • 最终当锚点值改变触发hashchange的回调函数,我们将指定的模板数据插入到DOM标识上

重定向和404

  • 进入后,默认就是/
  • 重定向 { path:'/' ,redirect:'/home' }
  • 重定向 { path:'/' ,redirect:{name:'home'} }
  • 404 : 在路由规则的最后的一个规则

    • 写一个很强大的匹配
    • { path:'*' , component:notFoundVue}

多视图

  • 以前可以一次放一个坑对应一个路由和显示一个组件

    • 一次行为 = 一个坑 + 一个路由 + 一个组件
    • 一次行为 = 多个坑 + 一个路由 + 多个组件
  • components 多视图 是一个对象 对象内多个key和value

    • key对应视图的name属性
    • value 就是要显示的组件对象
  • 多个视图<router-view></router-view> -> name就是default
  • <router-view name='xxx'></router-view> -> name就是xxx
  • name需要在router/index.js中声明.例如

router-view所在页面:

    <router-view></router-view> //对应xx页面
    <router-view name="footer"></router-view>//对应xxx页面
    <router-view name="header></router-view>//对应xxxx页面

router/index.js页面:

    components:{default:xx,footer:xxx,header:xxxx}

嵌套路由

  • 用单页去实现多页应用,复杂的嵌套路由
  • 开发中一般会需要使用
  • 视图包含视图
  • 路由父子级关系路由
期组件内包含着第一层router-view
{ name:'music' ,path:'/music', component:Music ,
children:[   子路由的path /就是绝对路径   不/就是相对父级路径
    {name:'music.oumei' ,path:'oumei', component:Oumei },
    {name:'music.guochan' ,path:'guochan', component:Guochan }
]
}  

axios

  • https://segmentfault.com/a/11...
  • post请求的时候,如果数据是字符串 默认头就是键值对,否则是对象就是application/json
  • this.$axios.get(url,options)
  • this.$axios.post(url,data,options)
  • options:{ params:{id:1}//查询字符串, headers:{ 'content-type':'xxxxx' },baseURL:'' }
  • 全局默认设置 :Axios.defaults.baseURL = 'xxxxx';
  • 针对当前这一次请求的相关设置

如何练习

  • 1:路由核心

    • 路由基本使用
    • 任选一种路由参数的方式(查询字符串)
    • 404(路由匹配规则)
    • 嵌套路由
    • 编程导航
  • 2:http请求

    • axios 发起get、post请求
    • axios挂载属性方式

相关文章:

  • 想熟悉PostgreSQL?这篇就够了
  • Kotlin Weekly 中文周报 —— 103
  • 洛谷P2765 魔术球问题(贪心 最大流)
  • Linux鸟哥(总)
  • JQuery 选择器与过滤器(随手笔记)
  • python人工智能爬虫系列:怎么查看python版本_电脑计算机编程入门教程自学
  • Django - 一对多数据示例
  • Apache 年度报告:Java 是项目开发使用最多的语言
  • SendSms短信发送相关记录
  • SQL Server2016 配置管理器
  • java 判断请求来自手机端还是电脑端
  • javascript - 封装ajax
  • 一例exchange DAG 成员服务器添加数据库副本的错误
  • UI设计能力质变方法论 - 设计师, 请理解什么是组件
  • 【MyBatis】缓存配置
  • JavaScript-如何实现克隆(clone)函数
  • 08.Android之View事件问题
  • 30天自制操作系统-2
  • co.js - 让异步代码同步化
  • CSS 专业技巧
  • js数组之filter
  • PAT A1092
  • puppeteer stop redirect 的正确姿势及 net::ERR_FAILED 的解决
  • SQL 难点解决:记录的引用
  • 案例分享〡三拾众筹持续交付开发流程支撑创新业务
  • 测试如何在敏捷团队中工作?
  • 普通函数和构造函数的区别
  • 前端相关框架总和
  • 通信类
  • 项目实战-Api的解决方案
  • 正则表达式
  • 智能网联汽车信息安全
  • FaaS 的简单实践
  • 阿里云移动端播放器高级功能介绍
  • #!/usr/bin/python与#!/usr/bin/env python的区别
  • #前后端分离# 头条发布系统
  • (vue)el-checkbox 实现展示区分 label 和 value(展示值与选中获取值需不同)
  • (初研) Sentence-embedding fine-tune notebook
  • (一一四)第九章编程练习
  • (转)全文检索技术学习(三)——Lucene支持中文分词
  • (转)如何上传第三方jar包至Maven私服让maven项目可以使用第三方jar包
  • .NET CORE 2.0发布后没有 VIEWS视图页面文件
  • .NET/C# 编译期能确定的字符串会在字符串暂存池中不会被 GC 垃圾回收掉
  • @param注解什么意思_9000字,通俗易懂的讲解下Java注解
  • @SpringBootApplication 包含的三个注解及其含义
  • @四年级家长,这条香港优才计划+华侨生联考捷径,一定要看!
  • [ C++ ] template 模板进阶 (特化,分离编译)
  • [ CTF ] WriteUp-2022年春秋杯网络安全联赛-冬季赛
  • [04] Android逐帧动画(一)
  • [AIGC] Kong:一个强大的 API 网关和服务平台
  • [APIO2015]巴厘岛的雕塑
  • [C#]扩展方法
  • [C++]类和对象【下】
  • [CSS]浮动
  • [E单调栈] lc2487. 从链表中移除节点(单调栈+递归+反转链表+多思路)