当前位置: 首页 > news >正文

django网站开发视频教程全屏家居网站模板

django网站开发视频教程,全屏家居网站模板,网站建设的费用预算如何写,dw做网站站点结论先行&#xff1a; <script setup> 是 Vue3 的语法糖&#xff0c;简化了组合式 API 的写法&#xff0c;实现了 “顶层的绑定”。例如&#xff1a; ① 声明的属性和方法无需 return&#xff0c;就可以直接在模板使用&#xff1b; ② 引入组件的时候&#xff0c;会自…

结论先行:

<script setup> 是 Vue3 的语法糖,简化了组合式 API 的写法,实现了 “顶层的绑定”。例如:

① 声明的属性和方法无需 return,就可以直接在模板使用;

② 引入组件的时候,会自动注册,无需通过 components 手动注册

③ 使用 defineProps 接收父组件传递的值,defineEmits 定义自定义事件

④ 默认不会对外暴露任何属性和方法,如果要暴露的话使用 defineExpose

⑤ useAttrs 获取属性,useSlots 获取插槽

 

 具体解析:

1、<script setup> 是什么? 

<script setup> 是在 Vue3.2 之后新增的语法糖,简化了组合式 API 的写法,并且运行性能更好。

在单文件组件 SFC 中使用 Composition 组合式 API 的 " 编译时 " 语法糖。

基本语法:需要在 <script> 代码块加上 setup 属性

<script setup>console.log('你好,script setup')
</script>

<script setup> 和 <script> 的执行时机是不同的:

  • 普通的 <script> 只会在组件第一次被引入的时候执行一次
  • 而 <script setup> 中的代码会在每次组件实例被创建的时候执行

 

2、<script setup> 语法糖的特点: 

① 不需要再手动写 setup(){ }

因为在 setup 函数中,所有 ES 模块导出都被认为是暴露给上下文的值。

<script setup>console.log('你好,script setup')
</script>

 ② 属性和方法无需返回,可以直接使用。

不需要写 return,直接声明数据就可以在模板中使用了。 因为已经在 <script setup> 标签中,实现了 “顶层的绑定”。

解决了之前需要将声明的变量、函数以及 import 引入的内容,通过 return 向外暴露才能模板中使用的问题。

<template><p>{{ msg }}</p>
</template><script setup>const msg = ref('hello')
</script>

 ③ 引入组件的时候,会自动注册,无需通过 components 手动注册。

<template><com>{{ msg }}</com>
</template><script setup>import com from './com.vue'
</script>

④ 使用 defineProps 接收父组件传递的值。

defineProps 是 Vue3 的一个宏函数,使用时可不导入,参数与 Vue2 的 props 选项相同。

defineProps 返回的 props 对象,是一个响应式 proxy 对象,特性与 reactive 基本相同。但是,定义的 props 对象的值是只读的,而且可以在模板中直接使用属性

<template><p>{{ msg }}</p>
</template><script setup>const props = defineProps({msg: String,name: {type: String,default: '默认值'}})console.log(props.name)props.name = 'haha' // 不能修改,声明的props的值是只读的
</script>

⑤ useAttrs 获取属性,useSlots 获取插槽,defineEmits 获取自定义事件,defineExpose 对外暴露

 useAttrs:接收父组件传递的属性和事件;

在组件中可以直接使用这些属性和事件,无需在 props 和 emits 中声明。在模板中就可以直接使用它们。

与 defineProps 相比,useAttrs 的优先级较低。

useAttrs 能够接收到所有属性,但不能够对接收到的属性进行类型校验和默认值设置。

<template><div><p>{{ title }}</p><button @click="onClick">点击</button></div>
</template><script setup>
import { useAttrs } from 'vue'
const { title, onClick } = useAttrs()
</script>

defineEmits:父组件向子组件传递函数; 

defineExpose:可以将子组件中的属性和方法暴露给父组件

默认不会对外暴露任何属性和方法

父组件:

<template><p>父组件</p><child ref="childRef" :value="parentValue" @func="func"/>
</template><script setup>
import child from "./child";const parentValue = ref('我是爸爸');
const func = (params) => {parentValue.value = params
};const childRef = ref(null);
onMounted(()=>{// 调用子组件中的参数和函数console.log(childRef.value.a);childRef.value.childFn();
});
</script><script>
export default {name: "parent"
}
</script>

子组件:

<template><p>子组件</p><p>{{ value }}</p><button @click="emit('func', '哈哈哈')">点击</button>
</template><script setup>
import { defineProps, defineEmits, defineExpose } from 'vue'// 接收父级传过来的参数
const props = defineProps(["value"]);
// 接收父级传过来的方法
const emit = defineEmits(["func"]);const childValue = '我是儿子';
const childFn = () => {console.log("我是子组件中的方法");
}// 将参数childValue和函数childFn暴露给父组件
defineExpose({childValue,childFn
});
</script><script>
export default {name: "child"
}
</script>

 

http://www.yayakq.cn/news/441300/

相关文章:

  • 网站模板建设教程芯片商城网站建设
  • 做戒烟网站素材wordpress 搜索排除
  • 网站升级维护期间能访问吗wordpress文章排序
  • 阿克苏网站建设服务wordpress jitpecj插件
  • wordpress地址怎么打开野狼seo团队
  • 长沙哪里学网站建设网站插件代码下载
  • 怎么在百度里面找网站wordpress 积分 文章
  • 网站建设与管理教材南京做公司网站公司
  • 买域名的网站有哪些杭州网站维护公司
  • 分销网站开发合同wordpress 个性博客主题
  • 建设企业网站前市场分析学做网站需要什么条件
  • 洛阳网站建设哪家专业百度识图软件
  • 推广网站的几种方法django网站开发规范
  • 舞蹈东莞网站建设太原找工作网站
  • 石家庄做网站备案有哪些公司网站如何做QQ登录
  • 成都网站制作创新互联wordpress版本不一致如何更换空间
  • 科技网站的一些案例展示建设工程公司名称大全
  • 做qq头像的网站有哪些商务网站前台模板
  • 网站建设维护多少钱周口搜索引擎优化
  • 廖雪峰的网站怎么做的株洲的网络营销公司有哪些
  • 元器件网站开发客户wordpress的交叉表单
  • 已备案网站新增接入广告软文范例大全100字
  • 服务器网站后台登陆密码黄框显示软件开发和编程的区别
  • 定制网站建设哪家便宜图片变视频制作软件
  • 长沙品牌网站制作服务报价成都百度推广公司地址
  • 公司一个人做网站网络营销实验报告
  • 什么是行业网站?自己做网站怎么弄
  • 广州网站设计服务制作网页的网站推荐
  • 网站域名重定向怎么做扬州工程信息网
  • 哪个网站做系统好做的比较好的二手交易网站有哪些