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

金华网站制作价格商标买卖

金华网站制作价格,商标买卖,定制 网站,织梦如何做淘宝客网站前端功能问题系列文章#xff0c;点击上方合集↑ 序言 大家好#xff0c;我是大澈#xff01; 本文约3000字#xff0c;整篇阅读大约需要5分钟。 本文主要内容分三部分#xff0c;第一部分是需求分析#xff0c;第二部分是实现步骤#xff0c;第三部分是问题详解。 …前端功能问题系列文章点击上方合集↑ 序言 大家好我是大澈 本文约3000字整篇阅读大约需要5分钟。 本文主要内容分三部分第一部分是需求分析第二部分是实现步骤第三部分是问题详解。 如果您只需要解决问题请阅读第一、二部分即可。 如果您有更多时间进一步学习问题相关知识点请阅读至第三部分。 1. 需求分析 实现一个CMS内容管理系统在后台进行内容编辑在官网更新展示内容。 关于后台的编辑功能大致分为两部分组件拖拽预览、组件内容编辑实时预览。 对于组件拖拽预览用户可以在含有各种功能组件的列表中选择需要的组件进行拖拽。将组件拖拽到预览画布中后可以在画布中预览组件的内容。 对于组件内容编辑实时预览用户可以点击编辑按钮显示对应组件的内容编辑信息。当修改组件内容时在画布中可以实时预览组件的变化。 2. 实现步骤 2.1 关于拖拽组件库的选择 关于拖拽组件库在github上有很多最热门的当属vuedraggable这个库。 它基于Sortable.js拥有完整的中文文档所以很多朋友在做拖拽功能时都会优先考虑它。 但是我在使用的过程中在组件拖拽、取消组件拖拽这里遇到了一些小问题。不知道是我操作的问题还是库本身存在BUG所以最终没有选用它。 于是我发现了一个更加好用的拖拽库vue-draggable-next。 它的出现是参考了vuedraggable这个库所以说很多用法很相似但是使用起来较之更加友善。总结为一个词自由。 下面我们的拖拽功能实现就是利用了vue-draggable-next这个库。 如果你对拖拽底层原理感兴趣并且有空余时间劳请阅至第三部分拖拽原理总结。 2.2 拖拽功能代码实例 模版和逻辑中代码都分为了三部分组件列表、预览画布、内容编辑。 布局时样式根据需求自定义此处只是提供了功能的基本逻辑实现。 使用时关于拖拽组件的需求根据文档中提供的属性和事件的描述灵活配置完善。 vue-draggable-next库文档地址https://github.com/anish2690/vue-draggable-next 安装依赖 npm install vue-draggable-next //or yarn add vue-draggable-next 模板代码 templatediv styledisplay: flex;cursor: pointer;!-- 组件列表 左侧 --div stylewidth:30vw;padding:30px;height:300px;border: 1px solid #000;text-align: centerh1组件列表/h1VueDraggableNext :listcomponentNameList :group{ name: people, pull: clone, put: false } :sortfalsediv v-forelement in componentNameList :keyelement.namediv stylepadding: 10px;background: #ccc;margin-bottom: 10pxel-button {{ element.name }}/el-button/div/div/VueDraggableNext/div!-- 预览画布 中间 --div stylewidth:30vw;padding:30px;height:300px;border: 1px solid #000;text-align: centerh1预览画布/h1VueDraggableNext :listcomponentList grouppeople :sortfalsediv v-for(element, index) in componentList :keyelement.namedivel-button clickchangeComponent(element) sizesmall编辑/el-buttonel-button clickdeleteComponent(index) sizesmall删除/el-button/divcomponent :iselement.component :detailselement.details/component/div/VueDraggableNext/div!-- 内容编辑 右侧 --div stylewidth:30vw;padding:30px;height:300px;border: 1px solid #000;text-align: centerh1内容编辑/h1div v-for(nowDetails, index) in nowComponentDetail.details :keyindex{{ nowDetails.key }}: el-input clearable v-modelnowDetails.value //div/div/div/template 逻辑代码 script setup import {markRaw, reactive, ref, watch, nextTick} from vue; // 引入需要拖拽的组件 import About from /views/AboutView.vue // 引入拖拽库 import { VueDraggableNext } from vue-draggable-next;// 组件列表数据 const componentNameList  [{// 组件IDcomponentId:0,// 组件名name:关于组件,// 组件描述description: 关于组件,// 组件信息component: markRaw(About),// 组件需要编辑内容details: About.props.details.default},{componentId:1,name:关于组件1,description: 关于组件1,component:markRaw(About),details: About.props.details.default}, ];// 预览画布数据 let componentList  reactive([]);watch(componentList, ()  {console.log(componentList, componentList) })// 画布中删除的点击事件 const deleteComponent  (index)  {componentList.splice(index, 1); };// 内容编辑数据 let nowComponentDetail  ref({});// 画布中编辑的点击事件 const changeComponent  (element)  {nowComponentDetail.value  element; }; /script 2.3 功能组件代码实例参考 此处提供了组件列表中任意功能组件的编写实例组件的具体功能根据需求自定义。 特别注意组件Props中details对象属性的结构写法要灵活应用。 模版代码 templatediv stylepadding: 10px;background: pink;margin-bottom: 10px{{ props.details.content }}/div /template逻辑代码 script setup import { defineProps } from vue;const props  defineProps({details: {type: Object,default: {content: {key: 内容,value: 我是About,},}} }) /script3. 问题详解 3.1 拖拽实现的底层原理 拖拽的实现原理可以简单描述为以下几个步骤 触发拖拽通过监听鼠标或触摸事件当用户按下鼠标左键或触摸屏幕时表示开始拖拽操作。 记录拖拽信息在拖拽开始时记录拖拽起始位置鼠标或触摸点的坐标以及需要拖拽的元素的初始位置相对于文档的坐标。 更新拖拽元素位置在拖拽过程中通过监听鼠标移动或触摸滑动事件计算鼠标或触摸点的当前位置并根据鼠标或触摸点的位置变化更新拖拽元素的位置。这可以通过修改元素的 CSS 属性如 left 和 top或使用 CSS 变换如 translateX 和 translateY来实现。 处理拖拽结束当用户释放鼠标左键或触摸结束时表示拖拽结束。此时可以执行一些操作如更新拖拽元素的最终位置、触发事件或回调函数等。 以下是拖拽实现的基本原理代码实例 // 获取拖拽元素 const draggableElement  document.getElementById(draggable);// 记录拖拽起始位置和拖拽元素的初始位置 let startX, startY, initialX, initialY;// 监听鼠标按下事件 draggableElement.addEventListener(mousedown, dragStart); draggableElement.addEventListener(touchstart, dragStart);// 监听鼠标移动事件 document.addEventListener(mousemove, drag); document.addEventListener(touchmove, drag);// 监听鼠标释放事件 document.addEventListener(mouseup, dragEnd); document.addEventListener(touchend, dragEnd);// 拖拽开始事件处理程序 function dragStart(event) {event.preventDefault();if (event.type  touchstart) {startX  event.touches[0].clientX;startY  event.touches[0].clientY;} else {startX  event.clientX;startY  event.clientY;}initialX  draggableElement.offsetLeft;initialY  draggableElement.offsetTop; }// 拖拽事件处理程序 function drag(event) {event.preventDefault();if (event.type  touchmove) {const currentX  event.touches[0].clientX - startX;const currentY  event.touches[0].clientY - startY;draggableElement.style.left  initialX  currentX  px;draggableElement.style.top  initialY  currentY  px;} else {const currentX  event.clientX - startX;const currentY  event.clientY - startY;draggableElement.style.left  initialX  currentX  px;draggableElement.style.top  initialY  currentY  px;} }// 拖拽结束事件处理程序 function dragEnd() {// 执行拖拽结束后的操作 }3.2 关于vue-draggable-next 库的功能总结 vue-draggable-next 库特点和功能的补充说明 基于 Vue 3vue-draggable-next 是为 Vue.js 3 版本设计的拖拽库充分利用了 Vue 3 的响应式系统和组合式 API。 轻量级和简单易用该库的代码量较少易于理解和使用。它提供了一组简单的指令和组件可以轻松地将拖拽功能集成到 Vue.js 应用程序中。 支持多种拖拽模式vue-draggable-next 支持多种拖拽模式包括自由拖拽、列表拖拽、网格拖拽等。您可以根据需求选择适合的拖拽模式。 自定义拖拽样式和行为该库允许您自定义拖拽元素的样式和行为。您可以定义拖拽时的样式、占位符元素、限制拖拽的范围等。 事件和回调支持vue-draggable-next 提供了一组事件和回调函数可以在拖拽过程中监听和处理各种事件。例如您可以监听拖拽开始、拖拽结束、拖拽元素排序等事件并执行相应的操作。 支持触摸设备该库对触摸设备提供了良好的支持可以在移动设备上实现流畅的拖拽交互。 结语 建立这个平台的初衷 打造一个仅包含前端问题的问答平台让大家高效搜索处理同样问题。 通过不断积累问题一起练习逻辑思维并顺便学习相关的知识点。 遇到难题遇到有共鸣的问题一起讨论一起沉淀一起成长。 感谢关注微信公众号“程序员大澈”然后加入问答群让我们一起解决实现所有BUG
http://www.dnsts.com.cn/news/211088.html

相关文章:

  • 织梦做的网站页面打不开ui界面设计总结心得
  • 芜湖市网站建设公司电子商务网站规划的原则有哪些
  • 网站建设 尚瑞科技腾讯企点是干嘛的
  • 鼎湖网站建设强的网站建设
  • 网站建设 部署与发布题库泰安齐鲁人才网
  • 动态购物网站开发源代码做网站用html5
  • 背景网站建设公司天津个人网站建设
  • win7下如何建设网站建网站公司郑州
  • 北京建设项目管理有限公司网站企业百度网站怎么做
  • 门户网站建设企业网站正能量晚上不用下载进入免费
  • 今天的新闻联播内容官网首页优化
  • 佛山做企业网站聚星科技过会
  • 网站被k多久可以恢复网站栏目页怎么做
  • 深圳网站建设代理115做网站
  • 企业网站的制作重庆住房和城乡建设厅网站首页
  • 网站建设企业模板哪家好重庆网站制作权威乐云践新
  • 东莞网站建设推广公司简述网页布局的几种方法
  • 网站建立时间查询品牌建设浅谈
  • 现在注册公司好注册吗优化方案2021版语文答案
  • 做网站自适应框架wordpress post type
  • 杭州市萧山区市场建设开发网站做外账经常进哪几个网站
  • 龙岗建设网站自己名下备案的网站
  • nike网站开发背景及意义个人可以备案哪些网站
  • 怎么设置网站如何设计网站模板
  • 自己怎么注册一个网站中国建筑集团有限公司校园招聘
  • 北京网站建设一条龙网站后台生成器
  • 关于网站设计与建设的论文百度广告价格
  • 020网站建设合同范本如何在租用的服务器上部署自己的网站 mysql
  • 长春火车站附近美食软件培训
  • 做微商哪个网站比较好海外直播tiktok