欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

js实现点击生成随机div

程序员文章站 2022-06-22 14:11:22
本文实例为大家分享了js实现点击生成随机div的具体代码,供大家参考,具体内容如下 描述: 鼠标点击页面,在哪里点击就在那个位置创建一个div,宽高50, 颜色随机,div在鼠标...

本文实例为大家分享了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>

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