4.6日 js call css classList js 拖拽 十个心得

4 篇文章 0 订阅
2 篇文章 0 订阅

1.js比较有趣的一个我发现了

直接这么写:
var divs = document.querySelectorAll('div');

[].forEach.call(divs, function(div) {
  // do whatever
  div.style.color = "red";
});

感觉非常有意思,官方的解释,[] = Array.prototype 即为简写:详情参考 该链接


2.此外这里引申出一个点,

call方法,默认是把第一个参数代替

[1,2,3].forEach(function (num) { console.log(num); });

第一个参数,即用新的数组替代[1,2,3]


3.classList

每个元素都一个classList属性,默认访问时得到全部的clas集合


4.给元素添加拖拽效果思路:

首先得到全部的元素 boxs集合 使用document.querySelectorAll('#columns .box');

通过添加监听事件 dragstart dragenter dragover dragleave四个事件

通过在四个监听事件中加入this.classList.add('xxxx') 来加入元素的不同类 从而获取新的效果


5.阻止父元素监听到当前事件,阻止冒泡

e.stopPropagation()


6.拖拽时候的数据传递

e.dataTransfer.setData('text/html',this.innerHTML);  第一个参数类型 第二个参数必须为字符串

e.dataTransfer.getData('text/html');

此外dragenter允许通过e.dataTransfer.effectAllowed设置鼠标效果 和dragover  允许通过e.dataTransfer.dropEffect设置鼠标效果


7.阻止本身默认事件

e.preventDefualt()


8.四舍五入

toFixed() 方法可把 Number 四舍五入为指定小数位数的数字。


9.获取文件的方法

9.1.  在拖拽的过程中通过e.dataTransfer.files获取

9.2.  通过type='file'  得到它之后var files = document.getelementbyId("fileInput").files

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值