vue之滚动监听

简介: 如何实现监听和下载图标

屁话不多,先看效果。



上图是实现滚动右侧时,左侧图标类型也随之滚动。另外,当点击左侧图表类型时,右侧就会跳转到点击的类型。


实现监听


在新建好的vue中安装Element-UI、jQuery资源包。

先是基本页面布局,可以使用Element-UI中的布局组件更加快捷的实现。

这里需要注意的是图标的数据格式:


iconTypes: [
        {
          name: "类型一",
          icons: [
            {
              imgName: "1",
              name: "车车"
            },
            {
              imgName: "1.3",
              name: "车车"
            },
            {
              imgName: "1.5",
              name: "车车"
            }
          ]
        }   //此处省略多个类型下的图标数据
    ]


完成基本布局后,右侧加上id="scrollBox",方便点击时获取,在列表的li标签内加上触发的方法。


<ul class="type_ul">
          <li id="iconType" class="icon_li">图表类型</li>
          <li
            class="icon_li"
            v-for="(item,index) in types"
            :class="index==activeMenu?'active':''"
            @click="jump(index)"    //通过点击实现右侧div滚动
            :key="index"
          >
            <a class="type">{{item.name}}</a>
            <span class="num">{{item.num}}</span>
          </li>
    </ul>


核心功能方法实现:


listener() {    //监听页面滚动,加载时调用
      this.scrollBox = document.getElementById("scrollBox");
      const topArr = [];
      const jump = jQuery(".section");
      let top = 0;
      for (let i = 0; i < jump.length; i++) {
        topArr.push(jump.eq(i).position().top + top);
        top += 61;
      }
      let that = this;
      // 监听dom元素的scroll事件
      this.scrollBox.addEventListener(
        "scroll",
        () => {
          const current_offset_top = that.scrollBox.scrollTop;
          for (let i = 0; i < topArr.length; i++) {
            if (current_offset_top <= topArr[i]) {
              // 根据滚动距离判断应该滚动到第几个导航的位置
              that.activeMenu = i;
              break;
            }
          }
        },
        false
      );
    },
    jump(index) {   //点击类型,右侧滚动到相应位置
      this.activeMenu = index; // 当前导航
      const jump = jQuery(".section").eq(index);
      const scrollTop = jump.position().top + this.scrollBox.scrollTop - 60; // 获取需要滚动的距离
      // console.log("滚动的距离", this.scrollBox.scrollTop, index, scrollTop);
      // Chrome
      this.scrollBox.scrollTo({
        top: scrollTop,
        behavior: "smooth" // 平滑滚动
      });
    },


图标的下载


大家应该也遇到过和我一样的问题,下载文件时,直接点击浏览器就可以直接下载,只需要一个a标签就能够搞定。但是当遇到图片时,点击浏览器并不会直接下载。这是因为在点击文件时,文件地址浏览器不能够识别,所以会自动下载,但是图片就不同了。

想要下载图片,就需要使用canvas。


//点击图片a标签下载时,触发的方法
imgDownload(item) {
      let browserIsIe = this.browserIsIe();
      console.log(browserIsIe);
      if (!browserIsIe) {
        let filetype = "png";
        let canvas = document.createElement("canvas");
        let img = document.createElement("img");
        img.onload = function() {
          canvas.width = img.width;
          canvas.height = img.height;
          let context = canvas.getContext("2d");
          context.drawImage(img, 0, 0, img.width, img.height);
          canvas.toBlob(blob => {
            let a = document.createElement("a");
            a.href = window.URL.createObjectURL(blob);
            a.download = item.name;
            a.click();
          }, `image/${filetype}`);
        };
        img.setAttribute("crossOrigin", "Anonymous");
        img.src = "assets/imgs/" + item.imgName + ".svg";
        // img.src = "http://" + item.imgName;
      } else {
        window.location.href = "assets/imgs/" + item.imgName;
      }
    },
    //判断是否为Trident内核浏览器(IE等)函数
    browserIsIe() {
      if (!!window.ActiveXObject || "ActiveXObject" in window) {
        return true;
      } else {
        return false;
      }
    }


如果看不懂的,可以点击GitHub ^-^ !


作者:ClyingDeng

链接:https://juejin.cn/post/6844904202703994893

来源:稀土掘金

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

目录
相关文章
|
8天前
|
缓存 JavaScript 前端开发
vue学习第四章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中计算属性的基本与复杂使用、setter/getter、与methods的对比及与侦听器的总结。如果你觉得有用,请关注我,将持续更新更多优质内容!🎉🎉🎉
vue学习第四章
|
8天前
|
JavaScript 前端开发
vue学习第九章(v-model)
欢迎来到我的博客,我是瑞雨溪,一名热爱JavaScript与Vue的大一学生,自学前端2年半,正向全栈进发。此篇介绍v-model在不同表单元素中的应用及修饰符的使用,希望能对你有所帮助。关注我,持续更新中!🎉🎉🎉
vue学习第九章(v-model)
|
7天前
|
JavaScript 前端开发 开发者
vue学习第十章(组件开发)
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。本文深入讲解Vue组件的基本使用、全局与局部组件、父子组件通信及数据传递等内容,适合前端开发者学习参考。持续更新中,期待您的关注!🎉🎉🎉
vue学习第十章(组件开发)
|
13天前
|
JavaScript 前端开发
如何在 Vue 项目中配置 Tree Shaking?
通过以上针对 Webpack 或 Rollup 的配置方法,就可以在 Vue 项目中有效地启用 Tree Shaking,从而优化项目的打包体积,提高项目的性能和加载速度。在实际配置过程中,需要根据项目的具体情况和需求,对配置进行适当的调整和优化。
|
14天前
|
存储 缓存 JavaScript
如何在大型 Vue 应用中有效地管理计算属性和侦听器
在大型 Vue 应用中,合理管理计算属性和侦听器是优化性能和维护性的关键。本文介绍了如何通过模块化、状态管理和避免冗余计算等方法,有效提升应用的响应性和可维护性。
|
13天前
|
JavaScript 前端开发 UED
vue学习第二章
欢迎来到我的博客!我是一名自学了2年半前端的大一学生,熟悉JavaScript与Vue,目前正在向全栈方向发展。如果你从我的博客中有所收获,欢迎关注我,我将持续更新更多优质文章。你的支持是我最大的动力!🎉🎉🎉
|
13天前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript和Vue的大一学生。自学前端2年半,熟悉JavaScript与Vue,正向全栈方向发展。博客内容涵盖Vue基础、列表展示及计数器案例等,希望能对你有所帮助。关注我,持续更新中!🎉🎉🎉
|
14天前
|
存储 缓存 JavaScript
在 Vue 中使用 computed 和 watch 时,性能问题探讨
本文探讨了在 Vue.js 中使用 computed 计算属性和 watch 监听器时可能遇到的性能问题,并提供了优化建议,帮助开发者提高应用性能。
|
14天前
|
存储 缓存 JavaScript
Vue 中 computed 和 watch 的差异
Vue 中的 `computed` 和 `watch` 都用于处理数据变化,但使用场景不同。`computed` 用于计算属性,依赖于其他数据自动更新;`watch` 用于监听数据变化,执行异步或复杂操作。
|
14天前
|
存储 JavaScript 开发者
Vue 组件间通信的最佳实践
本文总结了 Vue.js 中组件间通信的多种方法,包括 props、事件、Vuex 状态管理等,帮助开发者选择最适合项目需求的通信方式,提高开发效率和代码可维护性。