JavaScript网站设计实践(三)设计有特色的主页,给主页链接添加JavaScript动画脚本

简介: 原文:JavaScript网站设计实践(三)设计有特色的主页,给主页链接添加JavaScript动画脚本一、主页一般都会比较有特色,现在在网站设计(二)实现的基础上,来给主页添加一点动画效果。 1、这里实现的动画效果是:当鼠标悬停在其中某个超链接时,会显示出属于该页面的背景缩略图,让用户知道这个链接的页面大概内容是什么。
原文: JavaScript网站设计实践(三)设计有特色的主页,给主页链接添加JavaScript动画脚本

一、主页一般都会比较有特色,现在在网站设计(二)实现的基础上,来给主页添加一点动画效果。

1、这里实现的动画效果是:当鼠标悬停在其中某个超链接时,会显示出属于该页面的背景缩略图,让用户知道这个链接的页面大概内容是什么。

效果图:

2、实现这个效果的思路

(1)把主页的几个链接的背景图片缩放到150px*150px,拼成一张750*150的图片,并保存为slideshow.png,存放到images文件夹里。

拼成来的图片是这样子的:

(2)写一个JavaScript脚本,用来生成动画效果。

脚本命名为home.js,存放在js文件夹下,并在webDesign.html下调用。

这个动画脚本的功能就是创建显示这个长图的标签,并将这个长图,根据你鼠标所在的连接,修改长图的left和top的属性值,并且实现移动,最后显示出来。

3、具体实现代码

(1)home.js

/********************主页动画脚本实现***********************/
function moveElement(elementID,final_x,final_y,interval){         //参数说明:移动元素的ID,移动的x坐标值,y坐标值,时间
                //向后兼容,判断旧浏览器
                if(!document.getElementById) return false;
                
                if(!document.getElementById(elementID)) return false;
                //获取元素
                var elem = document.getElementById(elementID);
                
                //判断图片是否已经有movement属性
                if(elem.movement){
                    clearTimeout(elem.movement);
                }
                
                //优化:判断left、top属性是否存在并初始化
                if(!elem.style.left){
                    elem.style.left = "0px"
                }
                if(!elem.style.top){
                    elem.style.top = "0px"
                }
                
                var xpos = parseInt(elem.style.left);                
                var ypos = parseInt(elem.style.top);
                //判断元素所在边界
                if(xpos == final_x && ypos == final_y) {
                    return true;
                }
                
                //改进动画效果
                if(xpos >final_x){
                    var dist = Math.ceil(( xpos- final_x)/10);
                    xpos = xpos -dist;
                }
                if(xpos <final_x){
                    var dist = Math.ceil((final_x - xpos)/10);
                    xpos = xpos +dist;
                }
                if(ypos <final_y){
                    var dist = Math.ceil((final_y - ypos)/10);
                    ypos = ypos + dist;
                }
                if(ypos >final_y){
                    var dist = Math.ceil((ypos - final_y)/10);
                    ypos = ypos -dist;
                }
                elem.style.left = xpos+"px";
                elem.style.top = ypos+"px";
                
                //执行moveElement()函数
                var repeat = "moveElement('"+elementID+"',"+final_x+","+final_y+","+interval+")";
                elem.movement = setTimeout(repeat,interval);
}

/****************V2在页面生成动画效果的代码**********************/
function prepareSlideshow(){
    //判断浏览器是否支持

    if(!document.getElementById) return false;
    if(!document.getElementsByTagName) return false;
    
    //判断元素是否存在
    if(!document.getElementById("intro")) return false;
    
    //动态生成html代码
    var intro = document.getElementById("intro");
    var slideshow = document.createElement("div");               //预留退路,如果用户禁掉js,则不出现不该出现的div
    slideshow.setAttribute("id","slideshow");
    
    var preview = document.createElement("img");
    preview.setAttribute("src","./images/slideshow.png");
    preview.style.position = "relative";                        //外部设置的postion获取不到,所以在这里设置
    preview.setAttribute("id","preview");
    slideshow.appendChild(preview);
    insertAfter(slideshow,intro);
    
    //获取元素
    var links = document.getElementsByTagName("a");
    
    for(var i= 0; i<links.length; i++){
        links[i].onmouseover = function(){
            var destination = this.getAttribute("href");
            if(destination.indexOf("webDesign.html") != -1){
                moveElement("preview",0,0,5);
            }
            if(destination.indexOf("about.html") != -1){
                moveElement("preview",-150,0,5);
            }
            if(destination.indexOf("photos.html") != -1){
                moveElement("preview",-300,0,5);
            }
            if(destination.indexOf("live.html") != -1){
                moveElement("preview",-450,0,5);
            }
            if(destination.indexOf("contact.html") != -1){
                moveElement("preview",-600,0,5);
            }
        }
    }
}

addLoadEvent(prepareSlideshow);

 

(2)webDesign.css

往这个文件添加样式

#slideshow{
width: 150px;
height: 150px;
position: relative;
overflow: hidden;
}

(3)在主页的webDesign.html把home.js文件加载进来

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

 

最后,ok啦,现在无论你的鼠标悬停在导航条的任意链接的上方,动画效果就会被触发,跟我们在最前面看到的效果一直,主页的动画脚本完成。

二、学与思

1、不知道如何用FW制作透明图片,于是把本来有frame窗框的图片给忽略了,在这里没有显示出来,就直接显示了图片。

2、关于外部css样式,本来有给动画图片设置了position:relative;  这个属性,但是对这个动画图片没有效果,甚为奇怪,最后还是在home.js文件中,给动画图片添加这个属性,本来应该是会有效果,有点不明白。

3、学习到了大图的相对定位,显示出小图来。通过移动相对定位的left和top属性,再把不要的hidden掉,再给一个动画,让这个图片移动起来即可。

 

目录
相关文章
|
5月前
|
前端开发 算法 API
构建高性能图像处理Web应用:Next.js与TailwindCSS实践
本文分享了构建在线图像黑白转换工具的技术实践,涵盖技术栈选择、架构设计与性能优化。项目采用Next.js提供优秀的SSR性能和SEO支持,TailwindCSS加速UI开发,WebAssembly实现高性能图像处理算法。通过渐进式处理、WebWorker隔离及内存管理等策略,解决大图像处理性能瓶颈,并确保跨浏览器兼容性和移动设备优化。实际应用案例展示了其即时处理、高质量输出和客户端隐私保护等特点。未来计划引入WebGPU加速、AI增强等功能,进一步提升用户体验。此技术栈为Web图像处理应用提供了高效可行的解决方案。
|
6月前
|
前端开发 JavaScript Java
【Java进阶】JavaScript电灯开关实例:从理论到实践
这个例子展示了JavaScript的基本功能,包括操作HTML元素,监听事件,以及改变元素的样式。通过学习和理解这个例子,你可以了解到JavaScript在网页中的应用,以及如何使用JavaScript来创建交互式的网页。
117 13
|
存储 JavaScript 前端开发
使用JavaScript构建动态交互式网页:从基础到实践
【10月更文挑战第12天】使用JavaScript构建动态交互式网页:从基础到实践
544 1
|
5月前
|
人工智能 监控 前端开发
基于 Next.js 的书法字体生成工具架构设计与 SSR 优化实践
本项目是一款书法字体生成工具,采用 Next.js 14(App Router)与 Tailwind CSS 构建前端,阿里云 Serverless 部署后端。通过混合渲染策略(SSG/SSR/CSR)、Web Worker 异步计算及 CDN 字体分片加载优化性能。服务端借助阿里云函数计算处理计算密集型任务,将平均耗时从 1200ms 降至 280ms,支持 1000+ QPS。动态路由与 ARMS 监控提升工程化水平,未来计划引入 WebGPU 和 AI 字体风格迁移技术,进一步优化用户体验。
|
8月前
|
JavaScript Shell C#
多种脚本批量下载 Docker 镜像:Shell、PowerShell、Node.js 和 C#
本项目提供多种脚本(Shell、PowerShell、Node.js 和 C#)用于批量下载 Docker 镜像。配置文件 `docker-images.txt` 列出需要下载的镜像及其标签。各脚本首先检查 Docker 是否安装,接着读取配置文件并逐行处理,跳过空行和注释行,提取镜像名称和标签,调用 `docker pull` 命令下载镜像,并输出下载结果。使用时需创建配置文件并运行相应脚本。C# 版本需安装 .NET 8 runtime。
490 3
|
11月前
|
JavaScript 前端开发
CSS3 动画和 JavaScript 动画的性能比较
具体的性能表现还会受到许多因素的影响,如动画的复杂程度、浏览器的性能、设备的硬件条件等。在实际应用中,需要根据具体情况选择合适的动画技术。
|
7月前
|
缓存 自然语言处理 JavaScript
JavaScript中闭包详解+举例,闭包的各种实践场景:高级技巧与实用指南
闭包是JavaScript中不可或缺的部分,它不仅可以增强代码的可维护性,还能在模块化、回调处理等场景中发挥巨大作用。然而,闭包的强大也意味着需要谨慎使用,避免潜在的性能问题和内存泄漏。通过对闭包原理的深入理解以及在实际项目中的灵活应用,你将能够更加高效地编写出简洁且功能强大的代码。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
11月前
|
JavaScript 前端开发
如何使用时间切片来优化JavaScript动画的性能?
如何使用时间切片来优化JavaScript动画的性能?
|
9月前
|
缓存 NoSQL JavaScript
Vue.js应用结合Redis数据库:实践与优化
将Vue.js应用与Redis结合,可以实现高效的数据管理和快速响应的用户体验。通过合理的实践步骤和优化策略,可以充分发挥两者的优势,提高应用的性能和可靠性。希望本文能为您在实际开发中提供有价值的参考。
203 11
|
前端开发 API 开发者
Next.js 实战 (五):添加路由 Transition 过渡效果和 Loading 动画
这篇文章介绍了Framer Motion,一个为React设计的动画库,提供了声明式API处理动画和页面转换,适合创建响应式用户界面。文章包括首屏加载动画、路由加载Loading、路由进场和退场动画等主题,并提供了使用Framer Motion和next.js实现这些动画的示例代码。最后,文章总结了这些效果,并邀请读者探讨更好的实现方案。
304 0
Next.js 实战 (五):添加路由 Transition 过渡效果和 Loading 动画

热门文章

最新文章