vue3使用arco.design组件输入框自动聚焦focus

描述

页面展示与编辑区分,用户点击编辑展示输入框,并且自动聚焦。

示例所用技术栈

vue3 + ts + tailwindcss
因此样式模块需要安装tailwindcss才能使用,否则需要删掉。

部分代码示例

 <span
              class="text-base"
              v-show="!element.isEdit"
            >
              {{ element.groupName? element.groupName:'未命名分组' }}
            </span>
            <a-input
              v-show="element.isEdit"
              ref="groupEditInputRef"
              :style="{width:'320px'}"
              placeholder="分组名字"
              allow-clear
              v-model="element.groupName"
              @blur="lostSate(element)"
            />
            <icon-edit
              v-show="!element.isEdit"
              size="20"
              class="ml-2 cursor-pointer hover:scale-[1.4] transition-all duration-[0.2]"
              @click="editGroupName(element)"
            />
// 点击编辑
// 注意; 控制显示的语句一定要放在前面
// * e.g:  element.isEdit = true
function editGroupName(element:any) {
  element.isEdit = true

  nextTick(() => {
    groupEditInputRef.value.focus()
  })
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要将vue3右键菜单组件固定在arco.design表格内部,可以使用以下步骤: 1. 首先,在arco.design表格的外层包裹一个相对定位的 div 元素,这个 div 元素的高度和宽度要与表格相同。 2. 在这个 div 元素内部添加一个绝对定位的 div 元素,这个 div 元素的高度和宽度也要与表格相同。 3. 在这个绝对定位的 div 元素内部添加右键菜单组件。 4. 为这个绝对定位的 div 元素添加一个事件监听器,当鼠标右键点击时,显示右键菜单组件。 5. 在右键菜单组件的样式中,设置 position: fixed,这样右键菜单组件就可以固定在表格内部。 下面是一个示例代码: ```html <template> <div class="table-container"> <div class="table-wrapper"> <a-table> <!-- 表格内容 --> </a-table> <div class="context-menu" v-show="showMenu" @click="handleMenuClick"> <!-- 右键菜单内容 --> </div> </div> </div> </template> <script> export default { data() { return { showMenu: false, menuX: 0, menuY: 0 }; }, mounted() { document.addEventListener("contextmenu", this.handleContextMenu); document.addEventListener("click", this.handleMenuClose); }, beforeUnmount() { document.removeEventListener("contextmenu", this.handleContextMenu); document.removeEventListener("click", this.handleMenuClose); }, methods: { handleContextMenu(e) { e.preventDefault(); this.menuX = e.clientX; this.menuY = e.clientY; this.showMenu = true; }, handleMenuClose() { this.showMenu = false; }, handleMenuClick() { // 处理右键菜单的点击事件 } } }; </script> <style> .table-container { position: relative; height: 400px; /* 表格高度 */ width: 100%; /* 表格宽度 */ } .table-wrapper { position: absolute; top: 0; left: 0; height: 100%; width: 100%; } .context-menu { position: fixed; top: 0; left: 0; z-index: 999; /* 右键菜单的样式 */ } </style> ``` 在这个示例中,我们使用了一个外层的相对定位的 div 元素来包裹arco.design表格,然后在这个 div 元素内部添加了一个绝对定位的 div 元素,将右键菜单组件放在这个 div 元素内部。在右键菜单组件的样式中,设置了 position: fixed,这样右键菜单组件就可以固定在表格内部了。我们还为这个绝对定位的 div 元素添加了一个事件监听器,当鼠标右键点击时,显示右键菜单组件

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值