Vue3 父组件传值给子组件+以及使用NModal组件

2024-01-11 17:52

本文主要是介绍Vue3 父组件传值给子组件+以及使用NModal组件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言:我想实现表格中点击详情弹窗出一个表格展示该行详细信息。想着这个弹窗里用子组件展示。分担父组件下,怕代码过多。(使用NModal组件弹窗展示)

等我一波百度,嗯,实现方法挺多嘛,什么refs什么的,看似条条大路通罗马,我一试,一试一条死路/(ㄒoㄒ)/~~,最后也没用到refs(我还是更倾向于用这个,毕竟vue2都是这样),一直说找不到$refs,我还去了解了底层**getCurrentInstance()**逻辑,有些又说不提倡这种方式,这个方法能看到我定义的的ref方法名,但是里面是null,又或者我当时子组件不是用的<script setup lang="ts">而是用的export default defineComponent下的setup(){},所以我不信邪,我子组件又改成了export default 还是不行。最后使用的defineProps
在这里插入图片描述

父组件:重点在 <child-detail :id="childRef"/>import childDetail from './childDetail.vue',以及需要改变childRef值的方法detailsEvent()

<template><div class="content-box"><n-form label-placement="left"inlinelabel-width="120px"><n-form-item label="UserName/Email"><n-input v-model:value="usersListRef.name_email" type="text" @input="queryConditional":style="{ width: '420px' }" placeholder="Please enter username or email (At least three letters)" /></n-form-item><!-- <n-form-item label="Email"><n-input v-model:value="usersListRef.email" type="text" :style="{ width: '280px' }" placeholder="Please enter email" /></n-form-item> --></n-form><n-space vertical :size="12" ><n-data-table style="min-height:calc(100vh - 223px);":bordered="false":single-line="false":columns="columns":data="data":loading="loading":pagination="pagination"striped /></n-space></div><n-modalv-model:show="showModal"class="custom-card"preset="card":style="bodyStyle"title="Details"size="huge":bordered="false":segmented="segmented"><!-- <template #header-extra>!</template> --><child-detail :id="childRef"/><!-- <n-data-table:bordered="false":single-line="false":columns="columns":data="data":loading="loading":max-height="300":pagination="pagination"striped /> --><!-- <template #footer>尾部</template> --></n-modal>
</template><script lang="ts">
import {NInput, NSpace,NButton, NForm, NFormItem, NDataTable, NModal} from 'naive-ui'
import {ref, defineComponent, Ref, getCurrentInstance, onMounted } from 'vue'
import { apiTokenRequest } from "@/stores/modules/apiEncapsulation"
import type { PaidlicenseResult } from "../../api/classes";
import type { DataTableColumns } from 'naive-ui'
import type { DataResult } from "../../api/classes";
import { h } from 'vue'
import { NTag, NAvatar } from 'naive-ui'
import { createDiscreteApi} from "naive-ui"
import childDetail from './childDetail.vue'interface UsersListType {username : string | nullemail: string | nullname_email: string | nullpageSize: number
}interface UsersListAll {id: string
}export default defineComponent({components: {NInput,NSpace,NButton,NForm,NFormItem,NDataTable,NModal,PaidLicenseDetail// NSwitch
},setup(){const childRef = ref("")const proxy = getCurrentInstance()!.proxyconst {message} = createDiscreteApi(["message"])const { dialog } = createDiscreteApi(["dialog"])let showModal = ref(false)const loadingRef = ref(true)const imgUrl = new URL('../../assets/AccountCircleOutlined.svg', import.meta.url).hrefconst usersListRef = ref<UsersListType>({username: null,email: null,name_email: null, pageSize: 12})const usersListAllResult : Ref<UsersListAll[]> = ref([])const getPaidResultMethod =  async ()=>{await apiTokenRequest<UsersListAll[]>("url","get").then(function(res){if(res){console.log('list===', res);usersListAllResult.value = resloadingRef.value = falseconsole.log('usersListAllResult===>',  usersListAllResult.value);}})}getPaidResultMethod()const queryConditional =async () => {console.log('条件查询===>', res);}const createColumns = ({detailsLicenses,deleteItem,handleChange,statusRes}: {detailsLicenses: (rowData: UsersListAll) => void,deleteItem: (rowData: UsersListAll) => void,handleChange: (rowData: UsersListAll) => void,statusRes: (status: number) => boolean,}): DataTableColumns<UsersListAll> => {return [{title: 'Name',key: 'name'},{title: 'Avatar',key: 'headerUrl',width:"120px",render (row) {return h(NAvatar,{style: {height:'50px',width:'50px',},color: '#fff',round:true,bordered: true,src:row.headerUrl ? row.headerUrl:imgUrl},)}},{title: 'Action',key: 'actions',width:"260px",render (row) {return [h(NButton,{size: 'small',type: "info",// quaternary: true,onClick: () => detailsLicenses(row)},{ default: () => 'Licenses' }),h( // 启、禁用NButton,{size: 'small',style: {marginLeft: "10px",width: "70px"},type: 'primary',// quaternary: true,onClick: () => handleChange(row)},{ default: () =>  row.status>0 ? 'Enable':'Disable' }),h( // 删除NButton,{size: 'small',style: {marginLeft: "10px",},type:"error",// quaternary: true,onClick: () => deleteItem(row)},{ default: () => 'Delete' }),]}}]}const detailsEvent = async (rowData:UsersListAll)=>{showModal.value = truechildRef.value= rowData.id}const deleteEvent = async (rowData:UsersListAll)=>{}const handleChangeEvent = async (rowData:UsersListAll)=>{}return{childRef,usersListRef,usersListAllResult,showModal,loading: loadingRef,queryConditional,data: usersListAllResult,columns: createColumns({detailsLicenses (rowData) {message.info('send mail to ' + rowData.name)detailsEvent(rowData)},deleteItem(rowData){deleteEvent(rowData)},handleChange(rowData){handleChangeEvent(rowData)}}),pagination: {pageSize: usersListRef.value.pageSize// pageSize: 2},bodyStyle: {width: '60vw',// height: '60vh'},segmented: {content: 'soft',// footer: 'soft'} as const,}}
})
</script><style scoped>
</style>

子组件:都是重点。

<template><n-data-table:bordered="false":single-line="false":data="detailsData":loading="loading":columns="childColumns":max-height="300":pagination="pagination"striped /> 1111111{{ props?.id }}
</template><script lang="ts">
import {NInput, NSpace,NButton, NForm, NFormItem, NDataTable, NModal} from 'naive-ui'
import { defineComponent, ref, Ref, defineProps, onMounted } from 'vue'
import { apiTokenRequest } from "@/stores/modules/apiEncapsulation"
import type { Result } from "../../api/classes";
import type { DataTableColumns } from 'naive-ui'export default defineComponent({components:{NDataTable},
})
</script><script setup lang="ts">const props = defineProps({id:{type: String,}})const pagination = ref( {pageSize: 10})const loading = ref(true)let childColumns :anyconst detailsData : Ref<PaidlicenseResult[]> = ref([])const getDetail= async (id:string|undefined)=>{await apiTokenRequest<Result[]>("url","get").then(function(res){if(res){console.log('details===', res);loading.value = falsedetailsData.value = reschildColumns  = columns()console.log('=====detailsData===', detailsData.value);}})}getDetail(props.id)const columns = () => {return [{title:'id',key: 'id'}]}
</script>

我原本想await 调用getDetail() 会报错。setup function returned a promise, but no <Suspense> boundary was found in the parent component tree. A component with async setup() must be nested in a <Suspense> in order to be rendered. ,想用await是数据还没请求完,表格列名又加载了(当时还没有使用childColumns = columns()),就会同时出现这些报错type check failed for prop "columns". Expected Array, got Function Unhandled error during execution of setup function还有Unhandled error during execution of scheduler flush. This is likely a Vue internals bug. Please open an issue at。后面我想着,那就等数据请求成功后再调用columns(),用childColumns 字段赋值给组件。

这篇关于Vue3 父组件传值给子组件+以及使用NModal组件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/595221

相关文章

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

Spring StateMachine实现状态机使用示例详解

《SpringStateMachine实现状态机使用示例详解》本文介绍SpringStateMachine实现状态机的步骤,包括依赖导入、枚举定义、状态转移规则配置、上下文管理及服务调用示例,重点解... 目录什么是状态机使用示例什么是状态机状态机是计算机科学中的​​核心建模工具​​,用于描述对象在其生命

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

深入理解Go语言中二维切片的使用

《深入理解Go语言中二维切片的使用》本文深入讲解了Go语言中二维切片的概念与应用,用于表示矩阵、表格等二维数据结构,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录引言二维切片的基本概念定义创建二维切片二维切片的操作访问元素修改元素遍历二维切片二维切片的动态调整追加行动态

prometheus如何使用pushgateway监控网路丢包

《prometheus如何使用pushgateway监控网路丢包》:本文主要介绍prometheus如何使用pushgateway监控网路丢包问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录监控网路丢包脚本数据图表总结监控网路丢包脚本[root@gtcq-gt-monitor-prome

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

SpringBoot中如何使用Assert进行断言校验

《SpringBoot中如何使用Assert进行断言校验》Java提供了内置的assert机制,而Spring框架也提供了更强大的Assert工具类来帮助开发者进行参数校验和状态检查,下... 目录前言一、Java 原生assert简介1.1 使用方式1.2 示例代码1.3 优缺点分析二、Spring Fr

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

java使用protobuf-maven-plugin的插件编译proto文件详解

《java使用protobuf-maven-plugin的插件编译proto文件详解》:本文主要介绍java使用protobuf-maven-plugin的插件编译proto文件,具有很好的参考价... 目录protobuf文件作为数据传输和存储的协议主要介绍在Java使用maven编译proto文件的插件

SpringBoot线程池配置使用示例详解

《SpringBoot线程池配置使用示例详解》SpringBoot集成@Async注解,支持线程池参数配置(核心数、队列容量、拒绝策略等)及生命周期管理,结合监控与任务装饰器,提升异步处理效率与系统... 目录一、核心特性二、添加依赖三、参数详解四、配置线程池五、应用实践代码说明拒绝策略(Rejected