Vue3语法-双向绑定

点击加入精英计划可以加入

点击名字可以删除

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <!-- vue.js -->
    <script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>
</head>
<body>
<div id="app">
    <!-- 5.循环语句 -->
    <div>
        <h1>精英小组</h1>
        <!--
          n: 代表数组项,是一个变量,可以随意命名;所谓的数组项 就是数组中的 每一个值
          index: 代表的是数组的索引值,也是一个变量;
          names: 是要循环的数组名
         -->
        <h2 v-for="(n,index) in names" @click="del(index)">{{n}}</h2>
    </div>
    <!-- 6.双向绑定 表单标签: 输入框(输入框\单选框、复选框)、下拉框、文本域 -->
    <div>
        <input v-model="name">
        <button @click="add">加入精英计划</button>
    </div>
</div>
</body>
<script>
    // 引入
    const {createApp, ref} = Vue
    // 创建
    createApp({
        //setup 标记 Vue3 支持Vue3的语法 直接定义变量、函数都可以
        setup() {
            // const 常量 一般配合 ref(Vue3语法)把一个常量变成一个对象,这个对象默认拥有属性 value
            //变量 数组
            const names = ref([
                "zyd","mxq","wcs"
            ])

            //双向绑定
            const name = ref("")
            //增加
            const add = () => {
                names.value[names.value.length]=name.value;
            }
            //删除
            const del = (i) => {
                //splice 数组中删除,参数说明:1.从哪个索引开始删除 2.删除几个
              names.value.splice(i,1);
            }

            return {//只有返回的上面才可以使用
                names,name,add,del
            }
        }
    }).mount('#app')
</script>
</html>
相关推荐
灵感__idea4 小时前
Hello 算法:贪心的世界
前端·javascript·算法
GreenTea5 小时前
一文搞懂Harness Engineering与Meta-Harness
前端·人工智能·后端
killerbasd6 小时前
牧苏苏传 我不装了 4/7
前端·javascript·vue.js
吴声子夜歌7 小时前
ES6——二进制数组详解
前端·ecmascript·es6
码事漫谈7 小时前
手把手带你部署本地模型,让你Token自由(小白专属)
前端·后端
ZC跨境爬虫7 小时前
【爬虫实战对比】Requests vs Scrapy 笔趣阁小说爬虫,从单线程到高效并发的全方位升级
前端·爬虫·scrapy·html
爱上好庆祝7 小时前
svg图片
前端·css·学习·html·css3
橘子编程7 小时前
JavaScript与TypeScript终极指南
javascript·ubuntu·typescript
王夏奇8 小时前
python中的__all__ 具体用法
java·前端·python
叫我一声阿雷吧8 小时前
JS 入门通关手册(45):浏览器渲染原理与重绘重排(性能优化核心,面试必考
javascript·前端面试·前端性能优化·浏览器渲染·浏览器渲染原理,重排重绘·reflow·repaint