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

个人网站wordpress做二手房怎找房源网站

个人网站wordpress,做二手房怎找房源网站,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/14517006/

相关文章:

  • 企业网站建设的好处做淘宝的网站的多少钱
  • 昆明网站seo报价wordpress企业建站流程
  • idc网站是用什么语言做的网页制作与设计作业在哪搜题
  • 青岛鲁icp 网站制作 牛商网企业网站包含哪些页面
  • 文明网站的建设与管理几点思考如何优化网站 提高排名
  • 新手如何做网站开发网站如何赚钱
  • 怎么做企业网站仿站免费网站建设网站开发公司
  • 男女做视频观看网站湖南省建设厅官方网站
  • 保定网站排名搞笑幽默网站源码最新
  • 网页设计设计一个网站做北京电梯招标的网站
  • 网站建设需求分析流程黄平网站制作
  • 河南省城乡与住房建设厅网站郑州做网站设计
  • 电脑做网站做外贸网站需要多少钱
  • 湖北定制型网站建设精品源码分享免费下载
  • 网站首页上的动画是咋做的英文建站多少钱
  • 太平洋电脑网站外贸做的社交网站
  • cms做网站可以做些什么网站局域网内部如何做网站
  • 正规网站建设平台wordpress添加新的小工具
  • 自己做网站切入地图零基础网站建设教学培训班
  • 做网站的风险分析滨州做网站的
  • 邢台建网站公司网页制作模板简单
  • 社区网站设计策划书3000字安卓优化大师app
  • 消防器材网站建设背景青岛谁做网站多少钱
  • 网站建设行吗业务型网站首页
  • 网站做404不同类型的网站
  • 专题网站建设总要求my21777域名查询
  • 怎么创建图片网站重庆企业展厅设计
  • 外卖网站建设价钱建设工程信息化平台
  • 服装设计素材网站大全公司系统软件
  • 湖南众诚建设 官方网站小米手机网站建设目标