vue实例

  • vue2.x中创建vue实例,挂载到dom节点
点击查详情
<div id="vue_det">
<h1>site : {{site}}</h1>
<h1>url : {{url}}</h1>
<h1>{{details()}}</h1>
</div>
<script type="text/javascript">
var vm = new Vue({ //实例化vue,构造器
el: '#vue_det', //el表达式,类似css中id
data: { //定义属性
site: "菜鸟教程",
url: "www.runoob.com",
alexa: "10000"
},
methods: {//定义函数方法
details: function() {
return this.site + " - 学的不仅是技术,更是梦想!";
}
}
})
//可直接使用该实例对象
vm.site = "goushen"
//$用户区分属性
document.write(vm.$el === document.getElementById('vue_det')) // true
</script>
  • vue3.x创建vue实例,挂载到dom节点
点击查详情
<script type="text/javascript">
const HelloVueApp = {
data() {
return {
message: 'Hello Vue!!'
}
}
}
Vue.createApp(HelloVueApp).mount('#hello-vue')
</script> <script type="text/javascript">
Vue.createApp({
data(){
return{
msg : '重庆'
}
}
}).mount("#app")
</script> <script type="text/javascript">
// 创建 Vue 应用
const app = Vue.createApp({
})
// 定义名为 todo-item 的新组件
app.component('todo-item', {
template: `<li>This is a todo</li>`
})
// 挂载 Vue 应用
app.mount('#app')
</script>
  • vue-cli构建的vue项目
// main.js中创建vue实例
new Vue({
router,
render: h => h(App)
}).$mount('#app') // 等同于
new Vue({
router: router, // es6写法,注册router为vue的属性
render: function (createElement) { // 根组件App.vue作为vue的属性
return createElement(App);
}
}).$mount('#app')

参考

main.js作为入口文件,引入router、element-ui、vuex等,在main.js中将这些组件注册为vue实例的属性

router

  • 路由跳转:

    安装router、less、less-loader -> 新建组件 -> 配置路由 -> 路由出口 -> main.js中挂载到vue
// 新建子组件login.vue
<template>
<div>
登录组件
</div>
</template>
<script>
// 默认导出
export default {}
</script>
// style中可使用less,socped表示style只有在当前组件生效
<style lang="less" scoped>
</style> // router/index.js中配置路由
import Login from '../components/Login.vue'
Vue.use(VueRouter)
const router = new VueRouter({
routes: [
{path: '/', redirect: '/login'}, // 重定向
{path: '/login', component: Login} // 访问/login路由,跳转到login组件
]
}) // 根组件中编写路由出口
<router-view></router-view> // 在入口文件main.js中引入router/index.js,挂载到vue实例
import router from './router'
new Vue({
router,
render: h => h(App)
}).$mount('#app')
  • 子组件中执行路由跳转

    router/index.js中,将router引入、实例化、默认导出
import VueRouter from 'vue-router'
// 创建router实例
const router = new VueRouter({
routes: [
{path: '/home', component: Home}
]
})
// 导出
export default router // 入口文件中,导入router,作为vue实例的属性
import router from './router'
new Vue({
router, // es6语法,等同于 router: router,
render: h => h(App)
}).$mount('#app') // 相当于注册为vue的属性,子组件中直接跳转
this.$router.push("/home");

css样式

  • 全局样式放到assets/css/global.css;之后在入口文件main.js中引入

  • 在子组件的template标签中可使用html标签,style标签中使用样式

element-ui

  • element-ui使用
// 1. 安装插件vue-cli-plugin-element
// 2. element.js中引入所需组件,注册为自己的组件
import {Input} from 'element-ui'
Vue.use(Input)
// 3. 入口文件main.js中引入element.js,挂载到vue实例
import './plugins/element.js'
// 4. 直接在子组件中使用

参考

  • 可将element-ui的组件注册为vue实例的属性
// element.js中引入组件
import {Message} from 'element-ui'
// 挂载到vue实例的自定义属性message,这样就能通过this.$message使用Message
Vue.prototype.$message = Message
// login.vue中使用
this.$message.error("登录失败!");

axios

  • axios使用

    安装依赖axios -> 入口文件导入 -> 子组件中使用
// main.js中导入axios
import axios from 'axios'
// axios默认配置
axios.defaults.baseURL='http://localhost:8888/user'
// 将axios注册为vue实例的属性
Vue.prototype.$http = axios
// this.$http表示axios,post请求,参数一为路由,参数二为data
this.$http.post("login", this.loginForm);

vue项目梳理的更多相关文章

  1. Vue Vue项目目录结构梳理

    Vue项目目录结构梳理   by:授客 QQ:1033553122 1.   结构梳理   . ├── build/                      # webpack 配置文件: │   ...

  2. Vue项目结构梳理

    Vue项目结构图: 简单介绍目录结构 build目录是一些webpack的文件,配置参数什么的,一般不用动 config是vue项目的基本配置文件 node_modules是项目中安装的依赖模块 sr ...

  3. 入职一个月快速熟悉大型Vue项目经验感想

    来到和睦的公司家庭已经一个月出头了,从技术层面来说,公司项目PC端是我目前来说接触的最大最复杂的项目了,德老师也说这个不断开发更新迭代的项目的代码量相对于全国的web来说是蛮多的,对于快速熟悉这样的大 ...

  4. vue-cli快速构建Vue项目

    vue-cli是什么? vue-cli 是vue.js的脚手架,用于自动生成vue.js模板工程的. vue-cli怎么使用? 安装vue-cli之前,需要先装好vue 和 webpack npm i ...

  5. requirejs + vue 项目搭建2

    上篇是年后的项目搭建的,时间比较仓促,感觉有点low 1.gulp-vue 文件对公用js的有依赖,以后别的同事拿去搭其他项目,估计会被喷 2.不支持vue-loader一样写模版语言和es6语法 最 ...

  6. vue项目目录介绍

    Vue项目目录 初始化项目 vue init webpack []projectname] cd [projectname] npm install vue run dev 目录树 +---build ...

  7. Vue 项目实战系列 (一)

    最近一直在学习Vue,基本的文档看完后就需要进行具体的项目进行练手了,本系列文章主要是将我学习过程记录下来,和大家一起学习交流. 我在git上找到了一个淘票票的Vue项目,项目地址: https:// ...

  8. 简单vue项目脚手架(vue+webpack2.0+vuex+vue-router)

    github地址 使用技术栈 webpack(^2.6.1) webpack-dev-server(^2.4.5) vue(^2.3.3) vuex(^2.3.1) vue-router(^2.5.3 ...

  9. vue项目构建与实战

    关于 微信公众号:前端呼啦圈(Love-FED) 我的博客:劳卜的博客 知乎专栏:前端呼啦圈 前言 由于vue相对来说比较平缓的学习过程和新颖的技术思路,使其受到了广大前后端开发者的青睐,同时其通俗易 ...

随机推荐

  1. SpringBoot | 3.1 配置数据源

    目录 前言 1. 数据源的自动配置 2. *数据源自动配置源码分析 2.1 DataSourceAutoConfiguration:数据源自动配置类 2.2 JdbcTemplateAutoConfi ...

  2. python使用正则+jsonpath处理接口依赖

    1.接口2的入参值依赖接口1的响应结果,如接口2的入参ids需要拿到接口1响应结果的id字段值,测试用例写在excel中,参数:{"ids":"${$..id}$&quo ...

  3. python进程间的通讯实现

    1:进程间通讯的方法:apply_async()非阻塞式通讯     apply()阻塞式通讯 2:使用Queue实现对Process创建的进程间通讯, Queue本身是一个消息队列程序,Queue常 ...

  4. jvm源码解读--08 创建oop对象,将static静态变量放置在oop的96 offset处

    之前分析的已经加载的.Class文件中都没有Static 静态变量,所以也就没这部分的解析,自己也是不懂hotspot 将静态变量放哪里去了,追踪源码之后,看清楚了整个套路,总体上来说,可以举例来说对 ...

  5. 【LeetCode】841. 钥匙和房间

    841. 钥匙和房间 知识点:图:递归 题目描述 有 N 个房间,开始时你位于 0 号房间.每个房间有不同的号码:0,1,2,...,N-1,并且房间里可能有一些钥匙能使你进入下一个房间. 在形式上, ...

  6. 填坑-关于IIC通讯

    ​01.概述 在之前的文章中<STM32IIC详解>中详细讲解了IIC协议,并且使用是NXP的官方手册,demo示例使用IIC读取RTC芯片,运行正常,没有任何问题.并且更新了<II ...

  7. 浅谈Java类中的变量初始化顺序

    一.变量与构造器的初始化顺序 我们知道一个类中具有类变量.类方法和构造器(方法中的局部变量不讨论,他们是在方法调用时才被初始化),当我们初始化创建一个类对象时,其初始化的顺序为:先初始化类变量,再执行 ...

  8. YOLO-v4 口罩识别

    YOLO-v4 口罩识别 一.YOLO-v4概念 如果想要了解和认识yolo-v4的基本概念,首先要提的就是它的基础版本yolo-v1,对于yolo来说,最经典的算是yolo-v3.如果想要了解它的由 ...

  9. OpenGL学习笔记(二)画三角形

    目录 渲染管线(Graphics Pipeline) 编码实现 顶点数据 顶点缓冲对象(VBO) 顶点着色器 编译着色器 片段着色器 着色器程序 链接顶点属性 顶点数组对象 最终绘制三角形 索引缓冲对 ...

  10. AcWing 第11场周赛题解

    计算abc 首先 \(0<=a<=b<=c\) 会随机给出 \(a+b,a+c,b+c,a+b+c\)的值 因为\(a,b,c\)都为正整数,所以\(a+b+c\)一定为最大值 然后 ...