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

微网站是不是就是手机网站百度新闻排行榜

微网站是不是就是手机网站,百度新闻排行榜,整站优化seo排名点击,wordpress搬家建立数据库连接时出错1. 树形结构显示 显示文件夹和文件:使用 el-tree 组件展示树形结构,文件夹和文件的图标通过 el-icon 进行动态显示。文件夹使用 Folder 图标,文件使用 Files 图标。节点点击:点击树形节点后,会将选中的节点保存到 sel…

1. 树形结构显示
  • 显示文件夹和文件:使用 el-tree 组件展示树形结构,文件夹和文件的图标通过 el-icon 进行动态显示。文件夹使用 Folder 图标,文件使用 Files 图标。
  • 节点点击:点击树形节点后,会将选中的节点保存到 selectedNode 中,方便后续操作(如重命名、删除)。
2. 创建文件夹
  • 在根目录或者当前选中的文件夹下,点击 新建文件夹 按钮,触发 createFolder 方法创建一个新的文件夹。
  • 新文件夹将被添加到当前选中节点的 children 数组中,或者如果没有选中任何节点,则将文件夹添加到根目录。
3. 创建文件
  • 类似于文件夹,点击 新建文件 按钮,触发 createFile 方法创建一个新的文件,并将其添加到当前选中的文件夹下或者根目录。
4. 删除文件/文件夹
  • 通过点击 删除文件/文件夹 按钮,触发 removeFile 方法,删除当前选中的文件或文件夹。
  • 删除操作会检查所选文件夹或文件的父级节点,如果有父节点,直接从父节点的 children 中移除该项;如果是根节点,则从根目录数组中删除。
5. 重命名文件/文件夹
  • 通过右键点击某个节点,弹出自定义的上下文菜单。选择 重命名 选项后,触发 renameNode 方法,通过 prompt 弹窗输入新的名称,并更新节点的 label
6. 删除文件/文件夹(右键菜单)
  • 右键点击文件夹或文件,弹出自定义右键菜单,选择 删除 后会弹出确认对话框,确认删除后,调用 deleteNode 删除当前选中的文件/文件夹。
7. 上下文菜单
  • 在树形结构中,右键点击文件夹或文件时,会弹出自定义的上下文菜单,显示 重命名 和 删除 选项。
  • 上下文菜单会根据鼠标点击的位置动态显示,通过 contextMenuPosition 控制菜单的位置。
8. 事件监听
  • 点击外部区域隐藏上下文菜单:使用 document.addEventListener("click", handleOutsideClick) 监听点击事件,点击树形组件外部区域时,隐藏上下文菜单并清空选中的节点。
  • 组件卸载时移除事件监听:在组件卸载时,通过 onBeforeUnmount 钩子移除点击外部区域的事件监听,避免内存泄漏。

<script setup>
import { ref, onMounted, onBeforeUnmount } from "vue";
import { Folder, Files } from "@element-plus/icons-vue";// 在组件挂载后添加事件监听
onMounted(() => {document.addEventListener("click", handleOutsideClick);
});
// 在组件卸载前移除事件监听
onBeforeUnmount(() => {document.removeEventListener("click", handleOutsideClick);
});
// 定义树形数据
const data = ref([{label: "文件夹1",type: "folder",children: [{label: " 1-1",type: "folder",children: [{label: "1-1-1",type: "file",},],},],},{label: "文件夹2",type: "folder",children: [{label: "2-1",type: "folder",children: [{label: "2-1-1",type: "file",},],},{label: "2-2",type: "file",},],},{label: "文件夹3",type: "folder",children: [],},
]);// 配置树形数据的显示属性,指定文件夹使用 Folder 图标
const defaultProps = {children: "children",label: "label",icon: "icon", // 图标属性
};
// 当前选中的节点
const selectedNode = ref(null);
const handleNodeClick = (data) => {selectedNode.value = data;
};
// 监听点击事件,判断点击是否在树形组件外
const handleOutsideClick = (event) => {const treeElement = document.querySelector(".el-tree"); // 获取树形组件的 DOM 元素const buttonContainer = document.querySelector(".header"); // 获取按钮区域// 判断点击区域是否在树形组件或按钮区域外if (!treeElement.contains(event.target) &&!buttonContainer.contains(event.target)) {selectedNode.value = null; // 如果点击区域不是树或按钮区域,则清除选中的节点showContextMenu.value = false; // 隐藏菜单}
};
// 创建文件夹
const createFolder = () => {const newFolder = {label: "新文件夹",type: "folder",children: [],};if (selectedNode.value && selectedNode.value.type === "folder") {// 在选中的文件夹下创建selectedNode.value.children.push(newFolder);} else {// 根目录下创建data.value.push(newFolder);}
};// 创建文件
const createFile = () => {const newFile = {label: "新文件",type: "file",};if (selectedNode.value && selectedNode.value.type === "folder") {// 在选中的文件夹下创建selectedNode.value.children.push(newFile);} else {// 根目录下创建data.value.push(newFile);}
};// 删除文件或文件夹
const removeFile = () => {if (!selectedNode.value) {alert("请先选择一个文件或文件夹");return;}const parentNode = findParentNode(data.value, selectedNode.value);if (parentNode) {const index = parentNode.children.findIndex((item) => item.label === selectedNode.value.label);if (index !== -1) {parentNode.children.splice(index, 1);selectedNode.value = null; // 删除后清空选中的节点}} else {// 如果没有父节点,表示是根节点,直接从根节点删除const index = data.value.findIndex((item) => item.label === selectedNode.value.label);if (index !== -1) {data.value.splice(index, 1);selectedNode.value = null; // 删除后清空选中的节点}}
};
// 查找父节点
const findParentNode = (nodes, targetNode) => {for (let node of nodes) {if (node.children && node.children.includes(targetNode)) {return node;} else if (node.children) {const result = findParentNode(node.children, targetNode);if (result) return result;}}return null;
};
// 控制上下文菜单显示
const showContextMenu = ref(false); 
// 上下文菜单位置
const contextMenuPosition = ref({ top: 0, left: 0 }); 
//右键显示菜单
const handleContextMenu = (event, data, node) => {event.preventDefault(); // 阻止默认右键菜单selectedNode.value = node.data; // 保存当前节点showContextMenu.value = true; // 显示自定义右键菜单contextMenuPosition.value = { top: event.clientY, left: event.clientX }; // 设置菜单显示位置
};
//重命名
const renameNode = () => {if (selectedNode.value) {const newName = prompt("请输入新名称", selectedNode.value.label);if (newName) {selectedNode.value.label = newName; // 修改节点名称}}showContextMenu.value = false; // 隐藏菜单
};
//删除
const deleteNode = () => {if (selectedNode.value) {const confirmDelete = confirm(`确定删除 ${selectedNode.value.label} 吗?`);if (confirmDelete) {removeFile()}}showContextMenu.value = false; // 隐藏菜单
};
</script><template><div class="container"><header class="header"><!-- 新建文件和文件夹的按钮 --><el-button type="primary" @click="createFolder">新建文件夹</el-button><el-button type="primary" @click="createFile">新建文件</el-button><el-button type="primary" @click="removeFile">删除文件/文件夹</el-button></header><div class="main"><aside class="aside"><el-treestyle="max-width: 600px":data="data":props="defaultProps"@node-click="handleNodeClick"@node-contextmenu="handleContextMenu"><!-- 使用 render-content 插槽自定义节点显示 --><template #default="{ node, data }"><span><!-- 判断节点类型来动态显示图标 --><el-icon v-if="data.type === 'folder'"><Folder /></el-icon><el-icon v-if="data.type === 'file'"><Files /></el-icon>{{ data.label }}</span></template></el-tree><divclass="dropdown"v-if="showContextMenu":style="{position: 'absolute',top: contextMenuPosition.top + 'px',left: contextMenuPosition.left + 'px',}"><ul slot="dropdown"><li @click="renameNode">重命名</li><li @click="deleteNode">删除</li></ul></div></aside><div class="content"><!-- 内容区域 --></div></div></div>
</template><style scoped>
.container {width: 100%;height: 100%;display: flex;flex-direction: column;
}.header {height: 60px;border:1px solid #ccc;
}.main {flex: 1;display: flex;
}.aside {width: 200px;border-right: 1px solid #ccc;
}.content {flex: 1;padding: 10px;
}
.dropdown {position: absolute;background-color: #fff;padding:20px;border-radius: 5px;border:1px solid #ccc;
}
</style>

http://www.hengruixuexiao.com/news/19122.html

相关文章:

  • 企业网站建设需要哪些东西做网络推广有前途吗
  • 杭州网站定制开发杭州seo推广服务
  • 有网站和无网站的区别泰州seo排名扣费
  • 宝鸡做网站seo 排名 优化
  • 网站免费观影怎么做网站如何让百度收录
  • 政府网站建设素材收集通知惠州seo建站
  • 深圳营销型网站建设推广方案应该有哪些方面
  • 网站asp木马删除免费网站模板网
  • 乐清网站建设百度百度推广
  • 网站数据库怎么做种子搜索神器 bt 下载
  • 如何做垃圾网站赚钱吗织梦seo排名优化教程
  • 如何做商业网站推广制作一个网站的基本步骤
  • 网站虚拟主机购买教程营销网站建设流程
  • 网站运营者有没有免费的广告平台
  • wordpress 客户端配置岳阳seo
  • 网站与网页的区别如何制作app软件
  • 山西有哪些做网站的公司长沙优化网站厂家
  • 网站前台主要的功能是什么seo工资多少
  • 网站的虚拟人怎么做的肇庆seo排名外包
  • 济南网站建设网络公司营销网站建设价格
  • 交网站建设 域名计入什么科目上海b2b网络推广外包
  • 柳州 网站建设一级域名好还是二级域名好
  • 什么事三合一网站线上销售平台如何推广
  • 自己制作头像app软件安卓手机游戏优化器
  • 企业网站怎么制作百度一下你知道
  • 临清网站制作百度快速收录方法
  • 彩票网站我想自己做国内建站平台有哪些
  • 网站备案时间就是正式上线时间吗手游推广渠道
  • 如何做公司企业网站博客seo怎么做
  • 丹阳网站建设高明公司搜索seo