
写在前面
说来还是比较惭愧的,从周二开始事就比较多,周三电脑还坏了。
然后,就是各种乱七八杂、突如其来的破事,忙的团团转,由于走的过多了,导致不敢直腰,周四卧床一天。
之前都听说《陈情令》这部剧特别火。当然,肖战和王一博也正是因为这部剧火的,因此大多数人,也因为这部剧,被肖战和王一博圈粉。
而我可能是个例外吧,不敢点评什么,我怕我的评论区,爆炸,哈哈,万一被围攻呢?
我比较喜欢温宁这个角色,也就是居中的鬼将军,整部剧都是以2倍速看完的,主要都在看他,哈哈。

今天状态好点,就接着来更新了,下面就来更文了。

与Vue2对比
Vue3新特性
1、数据响应重新实现(ES6的proxy代替Es5的Object.defineProperty)
2、源码使用ts重写,更好的类型推导
3、虚拟DOM新算法(更快,更小)
4、提供了composition api,为更好的逻辑复用与代码组织
5、自定义渲染器(app、小程序、游戏开发)
6、Fragment,模板可以有多个根元素
Vue2、Vue3响应原理对比
1、Vue2使用Object.defineProperty方法实现响应式数据
2、缺点:
3、解决方案:
重写数组的方法,检测数组变更
1、Vue3使用proxy实现响应式数据
2、 优点:
3、缺点:
4、直观感受

使用Vue3进行数据绑定示例
上一篇我们已经实现了将后台返回数据,并在前台页面展示了(虽然是在控制台),但这也只能说明完成了90%。
接下来,就是我们怎么把后台接口返回数据,怎么展示到页面的过程了。
1、使用ref实现数据绑定
我们还是需要在Home里面修改,毕竟在页面展示,所以只需修改Home部分代码,具体示例代码如下:
<template>
<a-layout>
<a-layout-sider width="200" style="background: #fff">
<a-menu
mode="inline"
v-model:selectedKeys="selectedKeys2"
v-model:openKeys="openKeys"
:style="{ height: '100%', borderRight: 0 }"
>
<a-sub-menu key="sub1">
<template #title>
<span>
<user-outlined />
subnav 1
</span>
</template>
<a-menu-item key="1">option1</a-menu-item>
<a-menu-item key="2">option2</a-menu-item>
<a-menu-item key="3">option3</a-menu-item>
<a-menu-item key="4">option4</a-menu-item>
</a-sub-menu>
<a-sub-menu key="sub2">
<template #title>
<span>
<laptop-outlined />
subnav 2
</span>
</template>
<a-menu-item key="5">option5</a-menu-item>
<a-menu-item key="6">option6</a-menu-item>
<a-menu-item key="7">option7</a-menu-item>
<a-menu-item key="8">option8</a-menu-item>
</a-sub-menu>
<a-sub-menu key="sub3">
<template #title>
<span>
<notification-outlined />
subnav 3
</span>
</template>
<a-menu-item key="9">option9</a-menu-item>
<a-menu-item key="10">option10</a-menu-item>
<a-menu-item key="11">option11</a-menu-item>
<a-menu-item key="12">option12</a-menu-item>
</a-sub-menu>
</a-menu>
</a-layout-sider>
<a-layout-content
:style="{ background: '#fff', padding: '24px', margin: 0, minHeight: '280px' }"
>
{{ebooks}}
<pre>
{{ebooks}}
</pre>
</a-layout-content>
</a-layout>
</template>
<script lang="ts">
import { defineComponent,onMounted,ref } from 'vue';
import axios from 'axios';
export default defineComponent({
name: 'Home',
setup(){
console.log('set up');
const ebooks=ref();
onMounted(()=>{
axios.get("http://localhost:8888/ebook/list?name=spring").then(response =>{
console.log("onMounted");
const data=response.data;
ebooks.value=data.content;
})
})
return{
ebooks
}
}
});
</script>
知识点:
重新编译,启动服务,查看效果如下:

2、使用reactive实现数据绑定
同样,还是在Home里面修改,示例代码如下:
<template>
<a-layout>
<a-layout-sider width="200" style="background: #fff">
<a-menu
mode="inline"
v-model:selectedKeys="selectedKeys2"
v-model:openKeys="openKeys"
:style="{ height: '100%', borderRight: 0 }"
>
<a-sub-menu key="sub1">
<template #title>
<span>
<user-outlined />
subnav 1
</span>
</template>
<a-menu-item key="1">option1</a-menu-item>
<a-menu-item key="2">option2</a-menu-item>
<a-menu-item key="3">option3</a-menu-item>
<a-menu-item key="4">option4</a-menu-item>
</a-sub-menu>
<a-sub-menu key="sub2">
<template #title>
<span>
<laptop-outlined />
subnav 2
</span>
</template>
<a-menu-item key="5">option5</a-menu-item>
<a-menu-item key="6">option6</a-menu-item>
<a-menu-item key="7">option7</a-menu-item>
<a-menu-item key="8">option8</a-menu-item>
</a-sub-menu>
<a-sub-menu key="sub3">
<template #title>
<span>
<notification-outlined />
subnav 3
</span>
</template>
<a-menu-item key="9">option9</a-menu-item>
<a-menu-item key="10">option10</a-menu-item>
<a-menu-item key="11">option11</a-menu-item>
<a-menu-item key="12">option12</a-menu-item>
</a-sub-menu>
</a-menu>
</a-layout-sider>
<a-layout-content
:style="{ background: '#fff', padding: '24px', margin: 0, minHeight: '280px' }"
>
<strong>使用ref进行数据绑定结果:</strong><p></p>
{{ebooks1}}
<p></p>
<pre>
{{ebooks1}}
</pre>
<strong>使用reactivef进行数据绑定结果:</strong><p></p>{{ebooks2}}
<p></p>
<pre>
{{ebooks2}}
</pre>
</a-layout-content>
</a-layout>
</template>
<script lang="ts">
import { defineComponent,onMounted,ref,reactive,toRef} from 'vue';
import axios from 'axios';
export default defineComponent({
name: 'Home',
setup(){
console.log('set up');
//使用ref进行数据绑定
const ebooks=ref();
// 使用reactive进行数据绑定
const ebooks1=reactive({books:[]})
onMounted(()=>{
axios.get("http://localhost:8888/ebook/list?name=spring").then(response =>{
console.log("onMounted");
const data=response.data;
ebooks.value=data.content;
ebooks1.books=data.content;
})
})
return{
ebooks1: ebooks,
ebooks2:toRef(ebooks1,"books")
}
}
});
</script>
知识点:
重新编译,启动服务,查看效果如下:

写在最后
还是前端部分的开发给人的成就感更直观,因为可以直接看到效果,不像Controller或者Service中业务逻辑代码一样,写了好多,也看不出个所以然,但这也不影响我对Coding的喜欢。
到此,实现数据绑定部分介绍完,有兴趣的同学,请自行尝试。
————