为了账号安全,请及时绑定邮箱和手机立即绑定

通过在图像上滚动或按 +/- 按钮放大/缩小图像

通过在图像上滚动或按 +/- 按钮放大/缩小图像

aluckdog 2024-01-03 15:11:29
我有一些 razor 页面,每个页面包含 1~3 张图像。我希望如果我将鼠标悬停在它们上并滚动,放大或缩小取决于滚动方向,或者如果我按下 + / - 按钮缩放或缩小图像。我也想应用于所有图像,而不考虑页面有多少图像。我的意思是使用 querySelectorAll 或类似的东西适用类似于 googlemap 缩放,但适用于图像(jpg/png/...)最好全部用 JavaScript 编写有没有提到过选项的图书馆?
查看完整描述

2 回答

?
一只名叫tom的猫

TA贡献1906条经验 获得超3个赞

您可以尝试使用他们建议的脚本:

<script src="js/skrollr.js"></script>


查看完整回答
反对 回复 2024-01-03
?
慕村9548890

TA贡献1884条经验 获得超4个赞

我采取的方法是动态创建按钮并将其注入事件侦听器以放大/缩小图像。下面是我的意思的一个例子,如果您需要帮助理解其中的任何部分,请告诉我,


const scaleUp = image =>

{

  const scale = parseFloat(image.getAttribute('scaler'));

  image.style.transform = `scale(${scale + 0.1})`;

  image.setAttribute('scaler', Math.max(0, scale + 0.1));

};


const scaleDown = image =>

{

  const scale = parseFloat(image.getAttribute('scaler'));

  image.style.transform = `scale(${scale - 0.1})`;

  image.setAttribute('scaler', Math.max(0, scale - 0.1));

};


(async () =>

{

  const images = document.querySelectorAll('img');

  

  const buttonContainer = document.createElement('div');

  buttonContainer.style.position = 'absolute';

  buttonContainer.style.bottom = '15px';

  buttonContainer.style.width = '100%';

  buttonContainer.style.textAlign = 'center';

  

  for (let image of images)

  {

    await image.decode();

    const container = document.createElement('div');

    container.style.position = 'relative';

    container.style.display = 'inline-block';

    container.style.overflow = 'hidden';

    container.style.width = image.clientWidth;

    container.style.height = image.clientHeight;

    

    const containerImage = image.cloneNode();

    containerImage.setAttribute('scaler', '1');

    

    const plusButton = document.createElement('button');

    const minusButton = document.createElement('button');

    plusButton.textContent = '+';

    minusButton.textContent = '-';

    

    plusButton.addEventListener('click', () => scaleUp(containerImage), true);

    minusButton.addEventListener('click', () => scaleDown(containerImage), true);

    

    container.addEventListener('wheel', event =>

    {

      event.preventDefault();

      

      if (event.deltaY < 0) 

        scaleUp(containerImage);

      else if (event.deltaY > 0)

        scaleDown(containerImage);

    }, true);

    

    const imageButtonContainer = buttonContainer.cloneNode();

    imageButtonContainer.appendChild(minusButton);

    imageButtonContainer.appendChild(plusButton);

    

    container.appendChild(containerImage);

    container.appendChild(imageButtonContainer);

    image.replaceWith(container);

  }

})();

<img src="https://assets.pokemon.com/assets/cms2/img/pokedex/detail/001.png" />

<img src="https://assets.pokemon.com/assets/cms2/img/pokedex/detail/002.png" />

<img src="https://assets.pokemon.com/assets/cms2/img/pokedex/detail/003.png" />

<img src="https://assets.pokemon.com/assets/cms2/img/pokedex/detail/004.png" />

<img src="https://assets.pokemon.com/assets/cms2/img/pokedex/detail/005.png" />

<img src="https://assets.pokemon.com/assets/cms2/img/pokedex/detail/006.png" />


查看完整回答
反对 回复 2024-01-03
  • 2 回答
  • 0 关注
  • 99 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信