js实现点击生成随机div


Posted in Javascript onJanuary 16, 2020

本文实例为大家分享了js实现点击生成随机div的具体代码,供大家参考,具体内容如下

描述:

鼠标点击页面,在哪里点击就在那个位置创建一个div,宽高50,
颜色随机,div在鼠标点击的正中间

效果:

js实现点击生成随机div

实现:

js:

var Method=(function () {
  return {
    EVENT_ID:"event_id",
    loadImage:function (arr) {
      var img=new Image();
      img.arr=arr;
      img.list=[];
      img.num=0;
//      如果DOM对象下的事件侦听没有被删除掉,将会常驻堆中
//      一旦触发了这个事件需要的条件,就会继续执行事件函数
      img.addEventListener("load",this.loadHandler);
      img.self=this;
      img.src=arr[img.num];
    },
    loadHandler:function (e) {
      this.list.push(this.cloneNode(false));
      this.num++;
      if(this.num>this.arr.length-1){
        this.removeEventListener("load",this.self.loadHandler);
        var evt=new Event(Method.EVENT_ID);
        evt.list=this.list;
        document.dispatchEvent(evt);
        return;
      }
      this.src=this.arr[this.num];
    },
    $c:function (type,parent,style) {
      var elem=document.createElement(type);
      if(parent) parent.appendChild(elem);
      for(var key in style){
        elem.style[key]=style[key];
      }
      return elem;
    },
    divColor: function () {
      var col="#";//这个字符串第一位为# 颜色的格式
      for(var i=0;i<6;i++){
        col+=parseInt(Math.random()*16).toString(16);//rondom*16后的随机值即为0-1*16==0-16;  toString(16)为转化为16进制
      }
      return col;//最后返回一个七位的值 格式即为#nnnnnn 颜色的格式
    },
    random:function (min,max) {
      max=Math.max(min,max);
      min=Math.min(min,max);
      return Math.floor(Math.random()*(max-min)+min);
    },
    dragElem:function (elem) {
      elem.addEventListener("mousedown",this.mouseDragHandler);
      elem.self=this;
    },
    removeDrag:function (elem) {
      elem.removeEventListener("mousedown",this.mouseDragHandler);
    },
    mouseDragHandler:function (e) {
      if(e.type==="mousedown"){
        e.stopPropagation();
        e.preventDefault();
        document.point={x:e.offsetX,y:e.offsetY};
        document.elem=this;
        this.addEventListener("mouseup",this.self.mouseDragHandler);
        document.addEventListener("mousemove",this.self.mouseDragHandler);
      }else if(e.type==="mousemove"){
        this.elem.style.left=e.x-this.point.x+"px";
        this.elem.style.top=e.y-this.point.y+"px";
      }else if(e.type==="mouseup"){
        this.removeEventListener("mouseup",this.self.mouseDragHandler);
        document.removeEventListener("mousemove",this.self.mouseDragHandler);
      }
    }
  }
})();

html:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Title</title>
</head>
<script src="js/Method.js"></script>
<body>
  <script>
    init();
    function init() {
      document.addEventListener("mousedown",mouseHandler);
    }
 
    function mouseHandler(e) {
      var randomDiv=Method.$c("div",document.body,{
        width: "50px",
        height: "50px",
        position: "absolute",
        backgroundColor:divColor()
      })
      randomDiv.style.left=e.clientX-randomDiv.offsetWidth/2+"px";
      randomDiv.style.top=e.clientY-randomDiv.offsetHeight/2+"px";
/*      top:e.clientY-this.offsetHeight/2+"px",//原因 设置为了X...xbl
//      removeEventListener(randomDiv);*/
    }
 
    function divColor() {
      var col="#";//这个字符串第一位为# 颜色的格式
      for(var i=0;i<6;i++){
        col+=parseInt(Math.random()*16).toString(16);//rondom*16后的随机值即为0-1*16==0-16;  toString(16)为转化为16进制
      }
      return col;//最后返回一个七位的值 格式即为#nnnnnn 颜色的格式
    }
  </script>
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js刷新框架子页面的七种方法代码
Nov 20 Javascript
JavaScript的继承的封装介绍
Oct 15 Javascript
js行号显示的文本框实现效果(兼容多种浏览器 )
Oct 23 Javascript
举例讲解JavaScript中关于对象操作的相关知识
Nov 16 Javascript
Highcharts入门之简介
Aug 02 Javascript
jQuery+CSS3实现点赞功能
Mar 13 Javascript
Node+OCR实现图像文字识别功能
Nov 26 Javascript
微信小程序实现渐入渐出动画效果
Jun 13 Javascript
微信小程序用户授权弹窗 拒绝时引导用户重新授权实现
Jul 29 Javascript
JavaScript修改注册表实例代码
Jan 05 Javascript
解决vue项目,npm run build后,报路径错的问题
Aug 13 Javascript
微信小程序scroll-view不能左右滑动问题的解决方法
Jul 09 Javascript
关于vue3.0中的this.$router.replace({ path: '/'})刷新无效果问题
Jan 16 #Javascript
JS实现可视化音频效果的实例代码
Jan 16 #Javascript
js实现div色块碰撞
Jan 16 #Javascript
Vue实现 点击显示再点击隐藏效果(点击页面空白区域也隐藏效果)
Jan 16 #Javascript
vue列表数据发生变化指令没有更新问题及解决方法
Jan 16 #Javascript
使用Karma做vue组件单元测试的实现
Jan 16 #Javascript
js实现div色块拖动录制
Jan 16 #Javascript
You might like
PHP+Mysql日期时间如何转换(UNIX时间戳和格式化日期)
2012/07/15 PHP
php封装的图片(缩略图)处理类完整实例
2016/10/19 PHP
用ASP将SQL搜索出来的内容导出为TXT的代码
2007/07/27 Javascript
jquery修改属性值实例代码(设置属性值)
2014/01/06 Javascript
JS控制表单提交的方法
2015/07/09 Javascript
jQuery文字横向滚动效果的实现代码
2016/05/31 Javascript
JavaScript获取URL参数的方法之一
2017/03/24 Javascript
利用JS实现简单的瀑布流加载图片效果
2017/04/22 Javascript
详解Vue 普通对象数据更新与 file 对象数据更新
2017/04/26 Javascript
详解react服务端渲染(同构)的方法
2017/09/21 Javascript
微信小程序getPhoneNumber获取用户手机号
2017/09/29 Javascript
Vue实现美团app的影院推荐选座功能【推荐】
2018/08/29 Javascript
使用vue 国际化i18n 实现多实现语言切换功能
2018/10/11 Javascript
Vue项目自动转换 px 为 rem的实现方法
2018/10/29 Javascript
JS 创建对象的模式实例小结
2020/04/28 Javascript
vue中实现拖动调整左右两侧div的宽度的示例代码
2020/07/22 Javascript
jQuery实现计算器功能
2020/10/19 jQuery
uniapp微信小程序实现一个页面多个倒计时
2020/11/01 Javascript
vue使用transition组件动画效果的实例代码
2021/01/28 Vue.js
动态创建类实例代码
2009/10/07 Python
Python Deque 模块使用详解
2014/07/04 Python
Python实现螺旋矩阵的填充算法示例
2017/12/28 Python
pycharm 将python文件打包为exe格式的方法
2019/01/16 Python
python3+openCV 获取图片中文本区域的最小外接矩形实例
2020/06/02 Python
css3 transform属性详解
2014/09/30 HTML / CSS
Lookfantastic瑞典:英国知名美妆购物网站
2018/04/06 全球购物
驾驶员岗位职责
2014/01/29 职场文书
《世界多美呀》教学反思
2014/03/02 职场文书
运动会宣传口号
2014/06/09 职场文书
国企干部对照检查材料
2014/08/22 职场文书
乡镇个人对照检查材料
2014/08/22 职场文书
青年岗位能手事迹材料
2014/12/23 职场文书
禁毒主题班会教案
2015/08/14 职场文书
Python 中的单分派泛函数你真的了解吗
2021/06/22 Python
Spring Security使用单点登录的权限功能
2022/04/03 Java/Android
python pygame 开发五子棋双人对弈
2022/05/02 Python