Vue笔记

Vue基础学习笔记(三)

2018-07-24  本文已影响47人  许小花花

一、axios合并请求

export default {
    data(){
        return {}
    },
    created(){
        function getMsg(res1,res2){
            console.log(res1)
            console.log(res2)
        }
        this.$axios.all([
                this,axios.post('URL','key=value'),
                this.axios.get('URL')
            ])
            .then(this.$axios.spread(getMsg)) //分发响应
            .catch(err => { 
                console.log(err)
            })
    }
}

这样可以实现发送两个请求,只有所有都成功,才算是成功。只要有一个失败,就算是失败。

二、插槽slot

<navigation-link>
  Your Profile
</navigation-link>

当我们使用子组件navigation时,在子组件中写入一些内容,但是如果我们子组件的template中没有一个插槽slot,那么我们写入的Your Profile没有的地方放,子组件怎么知道要放在哪里呢,不知道放在哪里,所以它就干脆不放了,会把写的内容抛弃,大家就当无事发生过,子组件里怎么写,它就怎么呈现,全然不顾你在使用时写入的东西,当做没有看见。
但是如果我们在子组件中写入了一个插槽slot,那么我们传入的内容将会被在这个插槽处呈现。像下面这样

<a  v-bind:href="url" class="nav-link">
  <slot></slot>
</a>

渲染出来的结果将是:

<a  v-bind:href="url"  class="nav-link">
   Your Profile
</a>
<!--base-layout.vue-->
<div class="container">
  <header>
    <slot name="header"></slot>
  </header>
  <main>
    <slot></slot> <!--默认插槽-->
  </main>
  <footer>
    <slot name="footer"></slot>
  </footer>
</div>

然后在使用上面这个子组件时像下面这样

<base-layout>
  <template slot="header">
    <h1>Here might be a page title</h1>
  </template>

  <p>A paragraph for the main content.</p>
  <p>And another one.</p>

  <template slot="footer">
    <p>Here's some contact info</p>
  </template>
</base-layout>

在使用时,通过一个具有slot属性的标签,属性值对应slotname,将内容放到子组件的相应位置上去。
我们注意到,里面有一个没有指定nameslot,它就是默认插槽。所有在使用子组件时传入的东西,只要没有指定slot='slot的name',就都会放在这里。
我们还注意到,这里用的一个叫做template的标签,一定要用它吗?不是的,也可以直接放在h1或者p上面,像下面这样

<base-layout>
  <h1 slot="header">Here might be a page title</h1>

  <p>A paragraph for the main content.</p>
  <p>And another one.</p>

  <p slot="footer">Here's some contact info</p>
</base-layout>

但是,如果你并不只有一个h1,你还有其他内容也要一起放在这个插槽里,那你能怎么办,为每一个要放在插槽里的标签加slot吗?太麻烦啦!所以就一起放在template里面,给templateslot咯。

<button type="submit">
  <slot>Submit</slot> <!--Submit就是插槽的默认内容-->
</button>
<navigation-link url="/profile">
  Logged in as {{ user.name }} 
</navigation-link>

这里的user不是navigation-link的,而是父组件的

牢记一条准则:父组件模板的所有东西都会在父级作用域内编译;子组件模板的所有东西都会在子级作用域内编译。
<ul>
  <li  v-for="todo in todos"   v-bind:key="todo.id">
    {{ todo.text }}
  </li>
</ul>

这时,这里所获取的数据是子组件自己内部的数据。而我们在使用这个子组件时是无法获取它的(当然我们可以用以前学习过的父子组件间的通讯来实现),我们可以利用slot来达到这个目的

<ul>
  <li  v-for="todo in todos"  v-bind:key="todo.id" >
    <!-- 我们为每个 todo 准备了一个插槽,-->
    <!-- 将 `todo` 对象作为一个插槽的 prop 传入。-->
    <slot v-bind:todo="todo">
      <!-- 回退的内容 -->
      {{ todo.text }}
    </slot>
  </li>
</ul>

然后当我们使用todo-list组件的是时候,可以这样做

<todo-list v-bind:todos="todos">
  <!-- 将 `slotProps` 定义为插槽作用域的名字 -->
  <template slot-scope="slotProps">
    <!-- 为待办项自定义一个模板,-->
    <!-- 通过 `slotProps` 定制每个待办项。-->
    <span v-if="slotProps.todo.isComplete">✓</span>
    {{ slotProps.todo.text }}
  </template>
</todo-list>

这时即使我们是在父组件中,也还是可以获取到子组件的数据。其中slotProps只是一个名字,我们用slot-scope指定为什么名字,就可以在下面用xx.来获取子组件的data
在 2.5.0+,slot-scope 不再限制在 <template> 元素上使用,而可以用在插槽内的任何元素或组件上。

上一篇下一篇

猜你喜欢

热点阅读