JavaScript也能求爱哦

JavaScript也能求爱哦

这里面做了一个JavaScript的求爱小特效,效果例如以下:

不仅能出现以下的图的效果,还能够让这个图形尾随着鼠标转动哦,这里面仅仅是一个简单的没有修饰的小样例,基于这个样例能够让求爱,更加好玩了。闷骚男们,是不是能够给你的小萝莉发个这种网页啊。给力的。

<span>JavaScript也能求爱哦</span>

贴上code吧:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
<style type="text/css">
body{
	border:1px red solid;
	width:1000px;
	height:1000px;
	margin:0px auto;
	padding:0px;
	color:green;
}
/*
将对象从文档流中拖出,使用 left , right , top , bottom 等属性相对于
其最接近的一个最有定位设置的父对象进行绝对定位。假设不存在这种父对象,则
根据 body 对象。而其层叠通过 z-index 属性定义
*/
div{
position:absolute;
}
</style>
<script type="text/javascript">
//为什么要用onload,由于我在javascript代码中初始化时钟的div时,调试页面发现没有实现
//后来发现原因,html的代码是从前往后解析的。当先解析到JavaScript代码的时候,向body中
//加入�子节点的时候,找不到还未解析的body。所以应该先解析body的啦。方法有两种,一种就是下
//的写法,还有一种也能够是在body标签中加入�onload方法。
window.onload=function(){
	init();
};
//定义一个div数组,来存储12个div
//由于12个div位置上的关系,所以先确定一下圆点和半径,以便计算div的位置
var divs=[];
var loveBaby=["我","爱","你","!","宝","贝","你","爱","我","吗","勉","勉"]
var CX=300;
var CY=300;//----------------------网页中的位置坐标没有单位吗?
var R=150;
var divCenterNode;//中心点的位置要进行控制,设置全局变量
//定义一个初始化的函数
function init(){
	//创建一个中心点位置的div(能够写上求爱对象哦)
	divCenterNode=document.createElement("div");
	divCenterNode.innerHTML="婷婷,嫁给我吧!";
	document.body.appendChild(divCenterNode);
	divCenterNode.style.left=(CX-50)+"px";
	divCenterNode.style.top=(CY-30)+"px";
	//创建12个div组成一个禁止的时钟,放在body中
	for(var x=1;x<=12;x++){
		//创建div
		var divNode=document.createElement("div");
		divNode.innerHTML=loveBaby[x-1];
		//body对象不须要和其他对象一样去获取,js库中已经封装好了。
		document.body.appendChild(divNode);
		divs.push(divNode);
	}
	//每次启动startClock()对div元素进行又一次定位
	/*
	实际上要想达到旋转的效果,须要不断的进行偏移,或者说
	进行又一次定位,可是作循环,不能控制间隔多久启动函数,那么
	这时候window对象提供了方法。
	*/
	startClock();
	
}
//div的偏移量
var offset=0;//度数偏移量
//将位置的定位和转动单独定义一个函数
function startClock(){
	for(var x=1;x<=12;x++){
		var div = divs[x-1];
		//每个数字的度数
		var dushu=30*x+offset;
		//  角度值  * Math.PI /180 = 弧度值
		var divLeft = CX+R*Math.sin(dushu*Math.PI/180);
		div.style.left=divLeft+"px";
		var divTop = CY-R*Math.cos(dushu*Math.PI/180);
		div.style.top=divTop+"px";
	}
	offset+=50;
	//间隔一定的时间,回调这个函数
	//经过指定毫秒值后计算一个表达式。第一个參数是表达式,第二个參数是时间
	setTimeout(startClock,80);//window对象的方法
}
//定义这个时钟随着鼠标移动到不同的位置
function clockMove(event){
	CX=event.clientX;//鼠标所在位置的x坐标
	CY=event.clientY;//鼠标所在位置的y坐标
	divCenterNode.style.left=(CX-50)+"px";
	divCenterNode.style.top=(CY-30)+"px";

}
</script>
</head>
<body onmousemove="clockMove(event)">
<!-- 
一、把12个数字按一圈显示出来
	1\创建12个DIV,分别赋值 1--12
	2\给12个DIV定位,围成一圈。	
-->
</body >
</html>

本来是想做一个会转动,会跑的时钟显示。所以代码中的命名和时钟有关,就不纠结了,亲。初学javascript,感觉javascript非常强大。

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/119223.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • NotePad++ 正则表达式替换 高级用法[通俗易懂]

    NotePad++ 正则表达式替换 高级用法[通俗易懂]在我们处理文件时,很多时候会用到查找与替换。当我们想将文件中某一部分替换替换文件中另一部分时,怎么办呢?下面正则表达式给我提供方法。正则表达式,提供复杂并且弹性的查找与替换注意:不支持多行表达式(involving\n,\r,etc).1基本表达式PatternMeaning.匹配任意字符,除了新一行(\n)。也就是说“.”可以匹配\r,当文件中同时含有\ra

  • visual studio code使用方法_vscode自定义代码块

    visual studio code使用方法_vscode自定义代码块snippet,也即代码片,指的是能够帮助输入重复代码模式,比如循环或条件语句,的模板。本文即旨于详实地介绍如何在vscode中设置snippet。

  • MFC查找指定文件是否存在,PathFileExists 函数[通俗易懂]

    MFC查找指定文件是否存在,PathFileExists 函数[通俗易懂]MFC查找指定文件,VC++PathFileExists函数

  • 手把手教你搭建一个Git服务器

    手把手教你搭建一个Git服务器-Begin-前言现在有很多企业将Git或Svn使用作为一项工作技能体现在招聘要求中。相信大家都听过Github或Gitee,无论是Github还是Gitee,都是一个基于Git的代码托管平台,

  • js中的闭包[通俗易懂]

    js中的闭包[通俗易懂]闭包是js的一个难点也是它的一个特色,是我们必须掌握的js高级特性,那么什么是闭包呢?它又有什么用呢?我们都知道,js的作用域分两种,全局和局部,基于我们所熟悉的作用域链相关知识,我们知道在js作用域环境中访问变量的权利是由内向外的,内部作用域可以获得当前作用域下的变量并且可以获得当前包含当前作用域的外层作用域下的变量,反之则不能,也就是说在外层作用域下无法获取内层作用域下的变量,同样在不同的函…

  • Alex 的 Hadoop 菜鸟教程: 第6课 Hbase 安装教程「建议收藏」

    Alex 的 Hadoop 菜鸟教程: 第6课 Hbase 安装教程「建议收藏」这次给大家介绍一下Hbase的概念和安装教程

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号