如何实现图像内淡入淡出按钮的图像浏览

发布于 2024-11-02 12:30:00 字数 881 浏览 1 评论 0原文

我正在开发一个用于浏览图像的应用程序。我已经通过在图像外部使用标准文本锚点来实现浏览机制。

现在我想在图像“内部”实现浏览机制。让我们说清楚。 用户看到图像,并在 onMouseOver 事件发生时,根据指针指向图片的哪一侧,分别在右侧或左侧显示一个箭头。 在 onClick 事件发生后,在图片的右侧或左侧,用户应该能够浏览到上一张/下一张图像。无需单击箭头即可浏览。

现在我知道可以用Javascript实现这个功能,特别是jQuery框架有一些有趣的功能可以做到这一点。我遵循以下方法:

  1. 为图像创建一个 div 容器,并将 标签放入其中。

  2. 定义容器内导航箭头的位置。

  3. onMouseOver 事件时调用一个 jquery 函数,将箭头图像放置在步骤 2 中定义的位置。

  4. 使用一些fading函数来实现淡入淡出效果。

  5. 点击时调用已实现的图像浏览功能。

我的疑问主要是:

Q1)我的方法(上述几点)是否正确?

Q2) 如何根据图像大小调整浏览箭头的位置?

Q3) 如何让 jQuery“理解”用户是 onMouseOver 还是 onClicked 到图像的左侧或右侧?

虽然所有答案都受到赞赏,但我并不是要求纯代码在我的应用程序中复制粘贴和调整,但我想知道我的方法是否正确,并且有一些有用的 jQuery(或任何其他 JS 框架)函数来实现这个功能。

I am developing an application for browsing images. I have already implemented the browsing mechanism by using standard text anchors outside the image.

Now I would like to implement the browsing mechanism "inside" the image. Let's make it clear.
The user sees the image and upon onMouseOver event, depending on which side of the picture the pointer goes, it is shown an arrow respectively on the right or left side.
Upon onClick event, on the right or left side of the picture, the user should be able to browse to the previous/next image. It is not necessary to click on the arrow to browse.

Now I know that it is possible implement this function with Javascript, especially the jQuery framework has some interesting functions to do this. I am following this approach:

  1. Create a div container for the image and place the <img> tag inside.

  2. Define the position for the navigation arrows inside the container.

  3. Upon onMouseOver event call a jquery function that places an arrow image in the position defined at step 2.

  4. Use some fading function to implement the fade effect.

  5. Upon click call the image browsing functions already implemented.

My doubts are mainly about:

Q1) Is my approach (above listed points) correct?

Q2) How can I adjust the position of the browsing arrows depending on the image size?

Q3) How can make jQuery "understand" whether the user is onMouseOver or onClicked to the left or right part of the image?

Although all the answers are appreciated, I am not asking plain code to copy paste and adjust in my application, but I would like to know whether my approach is correct and have a couple of useful jQuery (or any other JS framework) functions to implement this functionality.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

凉墨 2024-11-09 12:30:00

Q1:你的方法正朝着正确的方向发展。

Q2:使用 jQuery,您可以读出元素的宽度,也可以使用 position:absolute; 定位箭头元素; right:20px ...但检查 Q3->

Q3:在您的停留中定义两个单独的 div,一个位于图像的右半部分,另一个位于图像的左半部分。所以结构可以是:

<div class="image-wrapper">
   <img src="somthing.jpg"/>
   <div class="navigation-overlay">
      <div class="left-arrow></div>
      <div class="right-arrow"></div>
   </div>
</div>

Q1: Your approach is going into the right direction.

Q2: With jQuery you can read out the width of an element or you can position the arrow element with position:absolute; right:20px ... but check Q3->

Q3: In your layover define two seperate divs, one on the right half the other on the left half over the image. So the structure could be:

<div class="image-wrapper">
   <img src="somthing.jpg"/>
   <div class="navigation-overlay">
      <div class="left-arrow></div>
      <div class="right-arrow"></div>
   </div>
</div>
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文