整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

JavaScript魔法:如何用几行代码实现令人惊艳的页面动态效果

着互联网的发展,网页的视觉效果越来越重要。为了吸引用户的注意力和提升用户体验,页面动态效果成为了不可或缺的一部分。JavaScript作为一种前端开发语言,可以帮助我们实现各种各样的页面动态效果。本文将介绍一些常见的页面动态效果,并提供实例代码供参考。

一、利用CSS和JavaScript实现简单的动态效果

1.1 利用CSS过渡效果实现淡入淡出效果

通过CSS的transition属性和JavaScript的classList方法,可以实现元素的淡入淡出效果。下面是一个实例代码:

<!DOCTYPE html>
<html>
<head>
<style>
.fade-in {
  opacity: 0;
  transition: opacity 1s ease-in-out;
}
.fade-in.show {
  opacity: 1;
}
</style>
</head>
<body>
<button onclick="fadeIn()">淡入</button>
<button onclick="fadeOut()">淡出</button>
<div id="box" class="fade-in">Hello, World!</div>
<script>
function fadeIn() {
  var box = document.getElementById("box");
  box.classList.add("show");
}
function fadeOut() {
  var box = document.getElementById("box");
  box.classList.remove("show");
}
</script>
</body>
</html>

1.2 利用CSS动画实现元素的旋转效果

通过CSS的@keyframes规则和JavaScript的classList方法,可以实现元素的旋转效果。下面是一个实例代码:

<!DOCTYPE html>
<html>
<head>
<style>
.rotate {
  animation: spin 2s infinite linear;
}
@keyframes spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}
</style>
</head>
<body>
<button onclick="rotate()">旋转</button>
<div id="box">Hello, World!</div>
<script>
function rotate() {
  var box = document.getElementById("box");
  box.classList.toggle("rotate");
}
</script>
</body>
</html>

二、利用JavaScript实现更复杂的动态效果

2.1 实现元素的平移和缩放

通过JavaScript修改元素的样式属性,可以实现元素的平移和缩放效果。下面是一个实例代码:

<!DOCTYPE html>
<html>
<head>
<style>
#box {
  width: 100px;
  height: 100px;
  background-color: red;
  position: relative;
  transition: transform 1s ease-in-out;
}
</style>
</head>
<body>
<button onclick="translate()">平移</button>
<button onclick="scale()">缩放</button>
<div id="box"></div>
<script>
function translate() {
  var box = document.getElementById("box");
  box.style.transform = "translate(100px, 100px)";
}
function scale() {
  var box = document.getElementById("box");
  box.style.transform = "scale(2)";
}
</script>
</body>
</html>

2.2 实现元素的颜色变化

通过JavaScript修改元素的样式属性,可以实现元素的颜色变化效果。下面是一个实例代码:

<!DOCTYPE html>
<html>
<head>
<style>
#box {
  width: 100px;
  height: 100px;
  background-color: red;
  transition: background-color 1s ease-in-out;
}
</style>
</head>
<body>
<button onclick="changeColor()">改变颜色</button>
<div id="box"></div>
<script>
function changeColor() {
  var box = document.getElementById("box");
  box.style.backgroundColor = "blue";
}
</script>
</body>
</html>

三、注意事项与最佳时间

3.1 优化性能

在实现动态效果时,要注意优化性能,避免因频繁的DOM操作导致页面卡顿。可以使用节流函数来限制事件的触发频率,减少不必要的DOM操作,提高页面性能。

3.2 兼容性考虑

在使用JavaScript实现动态效果时,要考虑不同浏览器的兼容性。可以使用现代化的JavaScript库或框架来解决兼容性问题,比如jQuery、React等。

结语:

通过本文的介绍,相信你已经掌握了一些利用JavaScript实现网页动态效果的技巧。记住要优化性能,考虑兼容性,并创造炸裂的动态效果来吸引用户的注意。

(内容仅供参考)

Java实现根据svg模版动态生成图片

使用场景

需要Java语言动态生成图片

用流程图简单说明下我这边工作中使用的场景

仅供参考

所以这里就需要生成证书了

我先给大家看下最终实现的图片效果

这里要先说明一下

  • 图片上的文字都是动态变化的即不同的订单对应的图片内容都不一样
  • 图片上还可以嵌入图片哦 比如上图的logo图片

下面说下我是如何解决的

通过PhantomJS来实现

这种方式是不能实现这个需求的

这个的原理就是对网页截图 但只能对于静态页面截图 不能根据不同的参数值动态生成图片

所以不提倡使用这种方式

但也介绍下这种使用方式 朋友们根据自己的实际需求情况有选择的使用

通过html代码实现图片的效果 放入web容器(比如nginx)中部署

这是h5代码

test文件夹下面的内容

安装一个docker nginx 将test文件夹加载到nginx容器的/usr/share/nginx/html目录下面

docker run --name nginx80  -p 8000:80  -v /tmp/test:/usr/share/nginx/html -d docker.io/nginx

访问的页面效果

访问该页面进行截图

这张图片是截图生成的图片 但url中的id值并没有传给页面

在h5代码中请求后端接口获取数据动态显示出来也是不可以的

所以这种方式使用局限性很窄

简单介绍下代码原理

大致原理是 通过http请求该url获取该url的文件流然后解析h5代码生成图片

通过SVG模版动态生成

先写svg模版(其实也是h5代码)

读取svg模版 动态传入参数生成图片

其实现原理大致为 读取svg document h5代码 将动态参数map解析到h5代码中 转换成字节数组 生成图片格式

Linux环境图片中文乱码

我本地是mac系统没有这个问题 在发布到测试环境linux系统出现了这个问题

先看下问题的现象

看到了没 生成的图片中文全是乱码

原因是因为linux系统没有中文字体

既然linux系统没有中文字体 那么就安装它嘛 let's 盘它!!!

先看下mac环境的字体情况

  • 安装字体管理工具
brew install fontconfig
  • 查看支持中文
fc-list :lang=zh    (注意‘:’前的空格)

mac环境默认会安装很多中文字体

再看下linux环境

  • 安装字体管理工具
yum -y install fontconfig
  • 查看支持中文
fc-list :lang=zh

果然没有中文字体

开始安装中文字体

将mac环境的宋体上传到linux环境

a 先在mac系统中找到字体安装目录

/System/Library/Fonts

b 找到宋体对应的文件

c 将该文件上传到linux指定的目录下

/usr/share/fonts/chinese

d 赋予文件夹操作权限

chmod -R 755 /usr/share/fonts/chinese

e 安装ttmkfdir来搜索目录中所有的字体信息,并汇总生成fonts.scale文件

yum -y install ttmkfdir

ttmkfdir -e /usr/share/X11/fonts/encodings/encodings.dir

修改字体配置文件

vi /etc/fonts/fonts.conf
添加
<dir>/usr/share/fonts/chinese</dir>

刷新内存中的字体缓存

fc-cache

确认是否安装成功

在jdk中安装该宋体

a 找到jdk所在的安装目录

echo $JAVA_HOME 

b 将宋体文件复制过来

cp /usr/share/fonts/chinese/STHeiti\ Light.ttc /usr/local/software/jdk1.8.0_141/jre/lib/fonts/fallback

fallback代表存放后备语言的文件夹

重启java服务即可

DEMO代码

https://gitee.com/pingfanrenbiji/resource/tree/master/image

注意: 引入的依赖问题

  <!--phantomjs -->
  <dependency>
   <groupId>org.seleniumhq.selenium</groupId>
   <artifactId>selenium-java</artifactId>
   <version>2.53.1</version>
  </dependency>
  <dependency>
   <groupId>com.github.detro</groupId>
   <artifactId>ghostdriver</artifactId>
   <version>2.1.0</version>
  </dependency>

  <!--svg-->
  <dependency>
   <groupId>com.github.hui.media</groupId>
   <artifactId>svg-core</artifactId>
   <version>2.5</version>
  </dependency>

这些依赖jar包我是上传到了公司的私服上了

若是朋友们下拉不下来

我提供给大家这些底层jar包的实现源码

https://gitee.com/pingfanrenbiji/quick-media

自行上传到自己的私服即可

、动态生成的html,样式不生效

//html 布局
<view v-html="html">
  {{html}}
 </view>

//动态生成的元素
<view class="btngo" @tap="handleLink(`${ajaxlink}`)" >
  去报名
</view>	
//然后scoped的.btngo不生效,因为v-html创建的DOM内容不受作用域内的样式影响,
//于是我们仍然可以通过深度作用选择器来为他们设置样式。
::v-deep {
  .btngo{
    display: inline-block;
    width: 200px;
    height: 44px;
    line-height: 44px;
    background-image: linear-gradient(180deg, #62AFFF 0%, #007BFF 100%);
  }
}

2、动态生成的html,点击事件不生效

让我醍醐灌顶的两种解决方法,我选择了第2种。

  • 1、使用事件委托
  • 2、绑定到外面不动态的元素上等着事件触发