1. this.$nextTick
veu中进行数据改变后,并不会马上刷新视图;用nextTick可告诉执行下个函数后马上刷新视图;
this.$nextTick(function(){
    //执行完该方法后刷新视图
})
 
2.ajax请求要用到的 axios
npm下载axios命令:
npm install --save axios
引用:在main.js中引用axios
//引入
import axios from 'axios'
//使用
Vue.prototype.$http=axios
 
3.inject
inject用来组件传递数据;
父组件和子组件传递数据可用 prop;
但是prop只能逐级传递,父组件想传递值给孙组件必须经过子组件;
inject可避免这一点,可在任意级别之间传递值,缺点是不容易追溯数据;
用vuex可解决组件之间值传递的问题,缺点是vuex太过庞大;
 
1)inject的用法:
    在父组件中用provide放入要传递的值;
    在后辈组件中用inject引入传递的值;
    在后辈组件模板中可以使用该值;
父组件
<template>
    <div class="test">
        <son prop="data"></son>
    </div>
</template>
<script>
export default {
    name: 'Test',
    provide: {
        name: 'Garrett'
    }
孙组件
<template>
    <div>{{name}}</div>
</template>
 
<script>
    export default {
    name: 'Grandson',
    inject: [name]
    }
</script>
 
2)props传递值
父组件:
    通过子组件中的props来传递值给父组件;
    父组件在模板中使用子组件时,通过子组件中定义的prop将值传递给子组件
<template>
    <div class="test">
        <son data="hello"></son>
    </div>
</template>
子组件:
<template>
    <div>
        <h1>{{data}}</h1>
    </div>
</template>
 
<script>
    export default {
        name: 'Son',
        props: ['data'],
    }
</template>
 
4.对全局安装和本地安装的理解
1)全局安装
命令:
npm install -g xxx
将包安装到全局安装文件夹;
node.js的全局安装文件夹默认时在c盘的用户目录下的npm文件夹;
prefix属性决定了全局安装目录的路径;在node.js安装目录的node_modules/npm目录下的npmrc文件来查看或修改;
也可通过npm config 命令来查看或修改全局安装文件夹的目录;
npm config ls    #查看npm配置信息
npm config set prefix xxx    #修改全局安装目录
npm config get prefix xxx    #查看全局安装目录
全局安装的模块一般是带有命令行的模块;比如vue-cli;
所以为了方便使用命令行,必须给全局安装目录配置环境变量;
 
2)本地安装
本地安装命令:
npm install xxx    
npm install --save xxx
npm install --save-dev xxx
本地安装将安装到命令行所在目录下的node_modules目录下,如果没有node_modules就新建一个;
比如说:命令行在c:\program File,执行本地安装命令后,文件就被安装在 c:\program File\node_modules\xxx ;
如果想在vue工程中安装就要先用cd命令切换到工程目录中去;
--save参数可在package.json中添加一条刚安装的包的依赖信息最好给加上;
--save-dev参数则添加依赖信息只在开发模式有用;
 
5.关于新建vue脚手架时的问题
$ vue init webpack exprice --------------------- 这个是那个安装vue脚手架的命令
This will install Vue 2.x version of the template. ---------------------这里说明将要创建一个vue 2.x版本的项目
For Vue 1.x use: vue init webpack#1.0 exprice
? Project name (exprice) ---------------------项目名称
? Project name exprice
? Project description (A Vue.js project) ---------------------项目描述
? Project description A Vue.js project
? Author Datura --------------------- 项目创建者
? Author Datura
? Vue build (Use arrow keys)
? Vue build standalone
? Install vue-router? (Y/n) --------------------- 是否安装Vue路由,也就是以后是spa(但页面应用需要的模块)
? Install vue-router? Yes
? Use ESLint to lint your code? (Y/n) n ---------------------是否启用eslint检测规则,这里个人建议选no
? Use ESLint to lint your code? No
? Setup unit tests with Karma + Mocha? (Y/n)
? Setup unit tests with Karma + Mocha? Yes
? Setup e2e tests with Nightwatch? (Y/n)
? Setup e2e tests with Nightwatch? Yes
vue-cli · Generated "exprice".
To get started: --------------------- 这里说明如何启动这个服务
cd exprice
npm install
npm run dev
 
6.关于路由的name属性
1)通过name属性,为一个页面中不同的router-view渲染不同的组件,如:将上面代码的Hello渲染在 name为Hello的router-view中,将text渲染在name为text的router-view中。不设置name的将为默认的渲染组件。
<template>
  <div id="app">
     <router-view></router-view>
     <router-view  name="Hello"></router-view> //将渲染Hello组件
     <router-view  name="text"></router-view>   //将渲染text组件
  </div>
</template>
 
2)可以用name传参 使用$router.name获取组件name值
<template>
     <div id="app"> 
        <p>{{ $route.name }}</p> //可以获取到渲染进来的组件的name值
         <router-view></router-view>
     </div>
</template>
 
3)用于pramas传参的引入 pramas必须用name来引入 query可以用name或者path来引入
   var router = new VueRouter({
      routes: [
        { name:'register', path: '/register/:id/:name', component: register }
      ]
    })
   <router-link :to="{name:'register',params:{id:10,name:'lili'}}">注册</router-link>
 
 
 

vue学习时遇到的问题(二)的更多相关文章

  1. vue学习时遇到的问题(一)

    1.vue的异步组件,require()方法 作用是:在需要使用的时候,从 根目录/components/HelloWorld.vue 加载组件 import Vue from 'vue' impor ...

  2. 我java学习时的模样(二)

    去掉自己浮躁的心 工作了三年,见识过高山,也见过低估,高山同大神一起共事,低估是几家特别烂的外包公司,现在有了另一种心境.已经开始重视自己,去掉当初浮躁的心. 毕业的一两年内,是人成长特别快的时期,也 ...

  3. vue学习指南:第十二篇(详细) - Vue的 路由 第二篇 ( 路由按需加载(懒加载))

    各位朋友 因 最近工作繁忙,小编停更了一段时间,快过年了,小编祝愿 大家 事业有成 学业有成 快乐健康 2020开心过好每一天.从今天开始 我会抽时间把 Vue 的知识点补充完整,以及后期会带给大家更 ...

  4. Vue学习之路第十二篇:为页面元素设置内联样式

    1.有了上一篇的基础,接下来理解内联样式的设置会更简单一点,先看正常的css内联样式: <dvi id="app"> <p style="font-si ...

  5. day 82 Vue学习二之vue结合项目简单使用、this指向问题

    Vue学习二之vue结合项目简单使用.this指向问题   本节目录 一 阶段性项目流程梳理 二 vue切换图片 三 vue中使用ajax 四 vue实现音乐播放器 五 vue的计算属性和监听器 六 ...

  6. day 81 Vue学习二之vue结合项目简单使用、this指向问题

    Vue学习二之vue结合项目简单使用.this指向问题   本节目录 一 阶段性项目流程梳理 二 vue切换图片 三 vue中使用ajax 四 vue实现音乐播放器 五 vue的计算属性和监听器 六 ...

  7. Vue学习笔记-Vue.js-2.X 学习(二)===>组件化开发

    ===重点重点开始 ========================== (三) 组件化开发 1.创建组件构造器: Vue.extends() 2.注册组件: Vue.component() 3.使用 ...

  8. vue学习笔记(二)——简单的介绍以及安装

    学习编程需要的是 API+不断地练习^_^ Vue官网:https://cn.vuejs.org/ 菜鸟教程:http://www.runoob.com/vue2/vue-tutorial.html ...

  9. vue 学习笔记(二)

    最近公司赶项目,一直也没时间看 vue,之前看下的都快忘得差不多了.哈哈哈,来一起回顾一下vue 学习笔记(一)后,继续向下看嘛. #表单输入绑定 基础用法 v-model 会忽略所有表单元素的 va ...

随机推荐

  1. php链接redis (带密码)常用的redis方法

    连接redis $redis = new Redis(); $redis->connect($host, $port); $redis->auth('my pass'); //密码验证 常 ...

  2. 初遇PHP(一)

    因为想给自己弄一个微信公众号,顺便提升一下自己,所以有了以下内容,本次学习的最终目标是能用php制作套微信公众号,然后转成Java.为什么要这么麻烦呢,其一是买的资料书是php的,其二是顺水推舟刚好可 ...

  3. Spring 注解介绍

    @Component与@Bean的区别 @Component注解表明一个类会作为组件类,并告知Spring要为这个类创建bean. @Bean注解告诉Spring这个方法将会返回一个对象,这个对象要注 ...

  4. 区间dp 整数划分问题

    整数划分(四) 时间限制:1000 ms  |  内存限制:65535 KB 难度:3   描述 暑假来了,hrdv 又要留学校在参加ACM集训了,集训的生活非常Happy(ps:你懂得),可是他最近 ...

  5. 如果你的评论被WordPress的Akismet插件屏蔽,怎么解封?

    Akismet是Matt Mullenweg早期创办的一个项目,现在已经是Automattic公司的一个专注于剿杀垃圾评论的产品.在Wordpress用户中使用最多,z-blog也有用户在用,由于垃圾 ...

  6. 移动端真机debug调试神器 vConsole学习(二)之实战

    项目中实际使用 在项目中实际使用的时候发现还是有很多问题的 最初使用方式  <script src="vconsole.min.js"></script> ...

  7. 测试使用Timer定时调用http接口

    转自:https://blog.csdn.net/qq_36004521/article/details/80101881

  8. VSCode中Markdown目录显示异常

    更新最新的VSCode之后编辑Markdown文件发现TOC标签的目录格式异常,发现是因为行尾字符导致,必须设置行尾字符进行解决.

  9. GitLab 部署及管理员账号初始化

    Linux系统搭建GitLab---阿里云Centos7搭建Gitlab踩坑一.简介GitLab,是一个利用 Ruby on Rails 开发的开源应用程序,实现一个自托管的Git项目仓库,可通过We ...

  10. python之字典二 内置方法总结

    Python字典包含了以下内置方法: clear()函数用于删除字典内所有元素 dict1 = {, 'Class': 'First'} print('the start len %d' % len( ...