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

个人网站wordpress宁波网站建设信任蓉胜网络好

个人网站wordpress,宁波网站建设信任蓉胜网络好,玉溪市网站建设推广,广东网站建设公司网络服务1) 背景: 老项目翻新时#xff0c;发现一个下拉框数据非常多#xff0c;客户呢#xff0c;希望全部数据一起展示#xff0c;意思就是全部数据一起返回给前端用于展示。但这会造成明显的卡顿。~~明显的不合理! QAQ!~~ 于是压力给到前端#xff0c;查询资料#xff0c;各种… 1) 背景: 老项目翻新时发现一个下拉框数据非常多客户呢希望全部数据一起展示意思就是全部数据一起返回给前端用于展示。但这会造成明显的卡顿。~~明显的不合理! QAQ!~~  于是压力给到前端查询资料各种搜索最终找到2个解决方案。     1、在el-select下拉框中添加分页组件让用户点击下一页下一页     2、在el-select下拉框中数据触底加载     当然最终选择了第二个方案用户体验会更好。     由于项目中有多个地方使用到 且 可能单个页面中会用到多次为了复用选择了自定义指令的方式去实现。      2) 先来看看实现的效果 3) 思路 触底加载哪个元素滚动触底时加载 承装下拉框中所有元素的容器(.el-scrollbar__wrap)触底时触发方法做什么 触底时继续向后端发请求获取下一页的数据请求回来的数据合并给options 4) 简单的写一下.vue文件代码 接口数据是自己用node写的 后端代码在这里GitHub - stella99888/tao-express: Vue2Express javascript!-- 下拉框触底加载页面 --templatediv classm-4p第一个select/pel-select v-modelvalue v-loadmoreloadmore :teleportedfalse stylewidth:240pxel-option v-foritem in options :keyitem.value :labelitem.label :valueitem.value //el-selectp第二个select/pel-select v-modelvalue v-loadmoreloadmore :teleportedfalse stylewidth:240pxel-option v-foritem in options :keyitem.value :labelitem.label :valueitem.value //el-select/div/templatescript setup import axios from axios; import { onMounted, reactive, ref } from vueconst list ref([]) const options ref([]) const option ref([]) const value ref([]) const loading ref(false) let pageData reactive({pageIndex: 1,pageSize: 10 }) onMounted(() {getOptions() }) const getOptions () {axios.get(http://localhost:9999/getSelectOptions?pageIndex${pageData.pageIndex}pageSize${pageData.pageSize}).then(res {console.log(res.data);if (res.data.length 1) {ElMessage({message: 没有更多数据了...,type: warning,});}const newOptions res.data.map((item) {return { value: item.name, label: item.index }})options.value.push(...newOptions)}) } // 触底了继续发请求 const loadmore () {pageData.pageIndex pageData.pageIndex 1getOptions() } /script * 注意一下:  1. teleported属性为官网提供是否将下拉列表插入至 body 元素默认值为true插入到body元素中。 这是插入body中的 这是不插入body中的可以对比下 2. 我们需要将其插入body元素中吗如果是单个页面中只出现一个那影响不大如果是多个我们要选中该元素时就很不方便了。   3. 且我们这边使用的是自定义指令的方式指令在el-select元素上teleported为false不插入body时正好可以在自定义指令中使用el.querySelector(.el-scrollbar__wrap)获取滚动的元素。   5) 自定义指令 前端代码在这里GitHub - wwaini/tao-vue3 at release240625 // src/directives/loadmore/index.js import { debounce } from lodash;export default {mounted(el, binding) {// 不插入body时以下方式可获取元素// 插入body时需要以document.querySelector(.el-scrollbar__wrap)获取let scrollWrap el.querySelector(.el-scrollbar__wrap)// 把监听的方法防抖一下const handle debounce((e) {let scrollDistance scrollWrap.scrollHeight - scrollWrap.scrollTop// 比如此处预留10个像素的位置用于触底if (scrollWrap.clientHeight 10 scrollDistance) {binding.value() // 触底通知一下外界}}, 170)// 绑定监听滚动事件scrollWrap?.addEventListener(scroll, handle)// 方法挂载到元素身上便于解绑时使用el._hanlde handle},unmounted(el, binding) {let scrollWrap document.querySelector(.el-scrollbar__wrap)scrollWrap?.removeEventListener(scroll, el._hanlde)el._hanlde null} } // directives/index.js import loadmore from ./loadmore // 自定义指令对象用于遍历注册 const directives {loadmore } // 批量注册指令并暴露到main.js中去便于注册 export default {install(app) {Object.keys(directives).forEach((key) {app.directive(key, directives[key])})} } // main.js import { createApp } from vue; import App from ./App.vue;const app createApp(App);// 引入并使用自定义指令 import directive from ./directives app.use(directive);app.mount(#app); // src/views/num/six.vue!-- 下拉框触底加载自定义指令 --templatediv classm-4p第一个select/pel-select v-modelvalue v-loadmoreloadmore :teleportedfalse stylewidth:240pxel-option v-foritem in options :keyitem.value :labelitem.label :valueitem.value //el-selectp第二个select/pel-select v-modelvalue v-loadmoreloadmore :teleportedfalse stylewidth:240pxel-option v-foritem in options :keyitem.value :labelitem.label :valueitem.value //el-select/div/templatescript setup import axios from axios; import { onMounted, reactive, ref } from vueconst list ref([]) const options ref([]) const option ref([]) const value ref([]) const loading ref(false) let pageData reactive({pageIndex: 1,pageSize: 10 }) onMounted(() {getOptions() }) const getOptions () {axios.get(http://localhost:9999/getSelectOptions?pageIndex${pageData.pageIndex}pageSize${pageData.pageSize}).then(res {console.log(res.data);if (res.data.length 1) {ElMessage({message: 没有更多数据了...,type: warning,});}const newOptions res.data.map((item) {return { value: item.name, label: item.index }})options.value.push(...newOptions)}) } // 触底了继续发请求 const loadmore () {pageData.pageIndex pageData.pageIndex 1getOptions() }/script如有不足欢迎指正。 不要忽视你达成的每个小目标它是你前进路上的垫脚石。冲
http://www.hkea.cn/news/14352772/

相关文章:

  • 做模具行业的网站沈阳网站营销
  • 如何在外管局网站做延期网站方案案例怎么做
  • 网站备案 座机温州网页制作模板
  • 商务网站建设的基本流程网站建设与推广长春
  • 备案 增加网站表单插件wordpress
  • 名字设计网站贵州二建报名入口官网
  • 北京怎样在社保网站上做减员江苏省住建厅官方网
  • 扬州做公司网站的公司建网站资阳哪家强?
  • 网站目录链接怎么做的wordpress关键词加内链
  • 电商商城网站建设免费网络电话软件哪个好用
  • 建设部网站如何下载国标规范服装企业官方网站
  • 网站开发维护印花税广州做网站seo
  • 网站建设从建立服务器开始企业服务公司的经营范围有哪些
  • 陕西最好的云营销网站建设公司郑州电商运营培训
  • 怎么自己编码做网站seo点评类网站
  • 曲周县建设局网站网站免费建站黄
  • 如何提高网站文章收录有哪几种语言做的网站
  • 西宁网站建设优化高青网站建设yx718
  • 查询网站用什么做的网站开发工程师的职责
  • 网站底部模板wordpress免费自定义模板装修教程
  • 做视频网站的流程西安企业免费建站
  • 百度收录网站名字网站建设夬金手指排名壹陆
  • 前端开发培训机构课程百度seo快排软件
  • wordpress网站被挂马微网站开发用什么技术
  • 电商网站建设系统天津网站优化指导
  • 深圳网站搭建找谁如何优化网络
  • 企业网站策划方案网站建设方案黎平网站建设
  • 商品网站建设网站开发技术三大件
  • 网站建设素材模板下载十大软件免费下载安装手机版
  • 安徽建设厅网站首页网站做图分辨率是多少合适