Vue + Ajax

Vue

一、什么是Vue ?

Vue 是一款用于构建用户界面的渐进式的JavaScript框架。 (官方网址:Vue.js - 渐进式 JavaScript 框架 | Vue.js

框架:就是一套完整的项目解决方案,用于快速构建项目 。 ​ 优点:大大提升前端项目的开发效率 。 ​ 缺点:需要理解记忆框架的使用规则 。(参照官网)

二、Vue的快速入门

准备环节: 1、引入Vue模块(官方提供)

2、创建Vue程序的应用实例,控制视图的元素

3、准备元素(div),被Vue控制

数据驱动视图:

1、准备数据 ​

2、通过插值表达式渲染页面

代码案例:

<!-- 3、准备元素(div),被Vue控制 -->
<div id="app">
    <!--通过插值表达式渲染页面 -->
    <h1>{{message}}</h1>
  </div>
  <!-- 1、引入Vue模块(官方提供) -->
  <script type="module">
    import { createApp } from 'https://unpkg.com/vue@3/dist/vue.esm-browser.js'
      // 2、创建Vue程序的应用实例,控制视图的元素
    createApp({
        //准备数据
      data() {
        return {
          message:'Hello Vue'
        }
      },
    }).mount('#app')//使用id选择器控制div
  </script>

三、常用指令

指令:HTML标签上带有 v-前缀的特殊属性,不同的指令具有不同的含义,可以实现不同的功能。

指令1:

v-for:列表渲染,遍历容器的元素或者对象的属性

作用:列表渲染,遍历容器的元素或者对象的属性 语法: v-for = "(item,index) in items" 参数说明: items 为遍历的数组 item 为遍历出来的元素 index 为索引/下标,从0开始 ;可以省略,省略index语法: v-for = "item in items"

<div id="app">
    <p v-for="item in name">{{item}}</p>
  </div>
  
  <script type="module">
    import { createApp } from 'https://unpkg.com/vue@3/dist/vue.esm-browser.js'
    createApp({
      data(){
        return {
          name: ['张无忌', '张三丰', '韦一笑', '殷天正']
        }
      }
    }).mount('#app')
  </script>

指令2:

v-bind:为HTML标签绑定属性值,如设置 href , css样式等

作用:动态为HTML标签绑定属性值,如设置href,src,style样式等。 语法:v-bind:属性名="属性值" 简化::属性名="属性值"

  
<div id="app">
    <a :href="url">链接1</a>
    <br><br>
    <a :href="url">链接2</a>
  </div>
  
  <script type="module">
    import { createApp } from 'https://unpkg.com/vue@3/dist/vue.esm-browser.js'
    createApp({
      data(){
        return {
           url:'https://www.itcast.cn'
        }
      }
    }).mount('#app')
  </script>

指令3:

v-if/v-else-if/v-else:条件性的渲染某元素,判定为true时渲染,否则不渲染

语法:v-if="表达式",表达式值为 true,显示;false,隐藏 原理:基于条件判断,来控制创建或移除元素节点(条件渲染) 场景:要么显示,要么不显示,不频繁切换的场景 其它:可以配合 v-else-if / v-else 进行链式调用条件判断

        <span v-if="user.gender == 1">男</span>
        <span v-else-if ="user.gender == 2">女</span>
        <span v-else>其他</span>

指令4:

v-show:根据条件展示某元素,区别在于切换的是display属性的值

语法:v-show="表达式",表达式值为 true,显示;false,隐藏 原理:基于CSS样式display来控制显示与隐藏 场景:频繁切换显示隐藏的场景

        <samp v-show="user.job == 1">班主任</samp>
        <samp v-show="user.job == 2">教师</samp>
        <samp v-show="user.job != 1 && user.job !=2">其他</samp>

指令5:

v-model:在表单元素上创建双向数据绑定

作用:在表单元素上使用,双向数据绑定。可以方便的 获取 或 设置 表单项数据 语法:v-model="变量名"

<body>
  
  <div id="app">
    <input type="text">
  </div>
  
  <script type="module">
    import { createApp } from 'https://unpkg.com/vue@3/dist/vue.esm-browser.js'
    createApp({
      data(){
        return {
          
        }
      }
    }).mount('#app')
  </script>
</body>

指令6:

v-on为html标签绑定事件(添加时间监听) 语法: v-on:事件名="内联语句" v-on:事件名="函数名“ 简写为 @事件名="…"

  
<div id="app">
    <input type="button" value="点我一下试试" @click ="headle">
    <input type="button" value="再点我一下试试" @click ="headle">
  </div>
  
  <script type="module">
    import { createApp } from 'https://unpkg.com/vue@3/dist/vue.esm-browser.js'
    createApp({
      data(){
        return {
          name: 'Vue'
        }
      },methods: {
        headle(){
          console.log("试试就试试");
        }
      },
    }).mount('#app')
  </script>

Ajax

一、什么是Ajax?

介绍:Asynchronous JavaScript And XML, 的JavaScript和XML①。 作用: 数据交换:通过Ajax可以给服务器发送请求,并获取服务器响应的数据。 异步交互:可以在不重新加载整个页面的情况下,与服务器交换数据并更新部分网页的技术,如:搜索联想、用户名是否可用的校验等等。

二、原生Ajax:

创建XMLHttpRequest对象:用于和服务器交换数据 向服务器发送请求 获取服务器响应数据

三、Axios

Axios 对原生的Ajax进行了封装,简化书写,快速开发。

引入Axios的js文件(参照官网) 使用Axios发送请求,并获取相应结果

method:请求方式,GET/POST url:请求路径 data:请求数据

为了方便起见,Axios已经为所有支持的请求方法提供了别名 格式:axios.请求方式(url [, data [, config]])

Vue生命周期

生命周期:指一个对象从创建到销毁的整个过程。 生命周期的八个阶段:每触发一个生命周期事件,会自动执行一个生命周期方法(钩子)。

  • 10
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值