js实现两点之间画线的方法


Posted in Javascript onMay 12, 2015

本文实例讲述了js实现两点之间画线的方法。分享给大家供大家参考。具体分析如下:

最近有点无聊,琢磨了很久,想到了一消磨时间的点子,也就是做js版的连连看。

两点之间画线也只是连连看最基本功能的一部分,所以我画的线也仅是折线,而且还只能向左折,后面将根据连连看中图片位置点来确定折线的方向。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>两点之间画折线</title>
<style type="text/css">
body{
 font-size:12px;
}
</style>
</head>
<script type="text/javascript">
<!--
var dot=new Array();
document.onmousedown =function(a) 
{ 
 //若div存在,则删除
 if(document.getElementById('line_div')){
 var clearDiv=document.getElementById("line_div");
 clearDiv.parentNode.removeChild(clearDiv);
 }
 //按下时创建一个事件
 if(!a) a=window.event;
 //获取x轴、y轴坐标
 var x=a.clientX;
 var y=a.clientY;
 //当数组长度大于等于4时,清空数组
 if(dot.length>=4) dot.splice(0,4);
 //将x、y添加到数组中,数组中保存了两组坐标值,相当于页面上的A(x1,y1)、B(x2,y2)两点
 dot.push(x,y);
 //当数组长度为4时,画线。
 if(dot.length==4){
 //计算div的长和宽
 var width=Math.abs(dot[0]-dot[2]);
 var height=Math.abs(dot[1]-dot[3]);
 //在页面上定位div左上角的具体位置
 var left=dot[0]-dot[2]<0?dot[0]:dot[2];
 var top=dot[1]-dot[3]<0?dot[1]:dot[3];
 //创建div
 var div=document.createElement("div");
 div.innerHTML=' <div id="line_div" style="width:'+width+'px;height:'+height+'px;position:absolute;visibility:visible;left:'+left+'px;top:'+top+'px;border-left:1px solid #cdcdcd;border-top:1px solid #cdcdcd;"></div>';
 document.body.appendChild(div);
 }
} 
-->
</script>
<body>
</body>
</html>

希望本文所述对大家的javascript程序设计有所帮助。

Javascript 相关文章推荐
Jquery 基础学习笔记之文档处理
May 29 Javascript
JQuery UI DatePicker中z-index默认为1的解决办法
Sep 28 Javascript
js实现星星打分效果的方法
Jul 05 Javascript
jQuery实现折叠、展开的菜单组效果代码
Sep 16 Javascript
JavaScript检查子字符串是否在字符串中的方法
Feb 03 Javascript
JS跨域请求外部服务器的资源
Feb 06 Javascript
JavaScript中常见的八个陷阱总结
Jun 28 Javascript
关于前后端json数据的发送与接收详解
Jul 30 Javascript
判断iOS、Android以及PC端的示例代码
Nov 15 Javascript
如何利用Node.js与JSON搭建简单的动态服务器
Jun 16 Javascript
vue实现简单加法计算器
Oct 22 Javascript
再也不怕 JavaScript 报错了,怎么看怎么处理都在这儿
Dec 09 Javascript
jquery简单实现图片切换效果的方法
May 12 #Javascript
浅谈javascript的分号的使用
May 12 #Javascript
JS中Location使用详解
May 12 #Javascript
js获取微信版本号的方法
May 12 #Javascript
javascript中基本类型和引用类型的区别分析
May 12 #Javascript
JavaScript模拟可展开、拖动与关闭的聊天窗口实例
May 12 #Javascript
Javascript中typeof 用法小结
May 12 #Javascript
You might like
php反射应用示例
2014/02/25 PHP
PHP调用VC编写的COM组件实例
2014/03/29 PHP
PHP一个简单的无需刷新爬虫
2019/01/05 PHP
jquery链式操作的正确使用方法
2014/01/06 Javascript
Bootstrap的图片轮播示例代码
2015/08/31 Javascript
js确认框confirm()用法实例详解
2016/01/07 Javascript
jquery获取文档高度和窗口高度汇总
2016/01/25 Javascript
AngularJS中$interval的用法详解
2016/02/02 Javascript
简单的JS轮播图代码
2016/07/18 Javascript
jQuery中ajax获取数据赋值给页面的实例
2017/12/31 jQuery
详解VUE2.X过滤器的使用方法
2018/01/11 Javascript
JS基于封装函数实现的表格分页完整示例
2018/06/26 Javascript
Vue 与 Vuex 的第一次接触遇到的坑
2018/08/16 Javascript
JS几个常用的函数和对象定义与用法示例
2020/01/15 Javascript
vue webpack build资源相对路径的问题及解决方法
2020/06/04 Javascript
nuxt.js服务端渲染中axios和proxy代理的配置操作
2020/11/06 Javascript
举例介绍Python中的25个隐藏特性
2015/03/30 Python
python黑魔法之编码转换
2016/01/25 Python
python3 破解 geetest(极验)的滑块验证码功能
2018/02/24 Python
Python网络编程基于多线程实现多用户全双工聊天功能示例
2018/04/10 Python
Python如何基于smtplib发不同格式的邮件
2019/12/30 Python
python3使用Pillow、tesseract-ocr与pytesseract模块的图片识别的方法
2020/02/26 Python
用python批量移动文件
2021/01/14 Python
Python3+SQLAlchemy+Sqlite3实现ORM教程
2021/02/16 Python
纯CSS绘制漂亮的圆形图案效果
2014/05/07 HTML / CSS
html特殊符号示例 html特殊字符编码对照表
2014/01/14 HTML / CSS
HTML5响应式(自适应)网页设计的实现
2017/11/17 HTML / CSS
瑜伽服装品牌:露露柠檬(lululemon athletica)
2017/06/04 全球购物
纽约家具、家居装饰和地毯店:ABC Carpet & Home
2017/06/21 全球购物
医学实习生自我鉴定
2013/12/12 职场文书
鲁迅故居导游词
2015/02/05 职场文书
小学生手册家长意见
2015/06/03 职场文书
导游词之上海杜莎夫人蜡像馆
2019/11/22 职场文书
利用 SQL Server 过滤索引提高查询语句的性能分析
2021/07/15 SQL Server
CPU不支持Windows11系统怎么办
2021/11/21 数码科技
详细介绍Next.js脚手架完整搭建封装
2022/04/26 Javascript