20151211小问题

1.事件对象的clientX/clientY,screenX/screenY,offsetX/offsetY,pageX/pageY,x/y

事件对象(event):就是发生事件时的元素,鼠标位置,鼠标状态,键盘按键的状态等事件里的细节状态.

打个比方,有个地方出了车祸,此时就有一个包含所有车祸事件状态的对象,它里面有发生车祸的人,发生车祸时车的位置,受伤情况等等.

比如一个点击事件,它的事件对象里,包含有许多的事件细节,状态.例如此时鼠标的位置,键盘的ctrl按键是否按下,shift按键是否按下等,事件名type,事件元素,时间戳timeStamp等一系列事件状态.

 

clientX/clientY:返回当事件被触发时,鼠标指针的水平/垂直坐标.鼠标相对于windows窗口的坐标.

screenX/screenY:返回当某个事件被触发时,鼠标指针的水平/垂直坐标.相对于电脑左/上屏幕的.

offsetX/offsetY:发生事件的地点在事件源元素的坐标系统中的x/y坐标.(IE属性),不被所有浏览器支持。只在你想要取得一个元素相对于它的绝对定位的父元素的位置时有用处。

pageX/pageY:这个东西是相对于document的。只是IE678不支持,IE9支持

x/y:事件发生的位置的x/y坐标,它们相对于用CSS动态定位的最内层包容元素.(IE属性),和clientX/clientY相似.

 

2.getComputedStyle,currentStyle(兼容性处理)

getComputedStyle是一个可以获取当前元素所有最终使用的CSS属性值.返回的是一个CSS样式声明对象([object CSSStyleDeclaration])只读.

obj.currentStyle[attr]在IE中有用,在FF和Chrome中报错.

“DOM2级样式”增强了document.defaultView,提供了getComputedStyle()方法。这个方法接受两个参数:要取得计算样式的元素和一个伪元素字符串(例如“:after”)。如果不需要伪元素信息,第二个参数可以是null。getComputerStyle()方法返回一个CSSStyleDeclaration对象,其中包含当前元素的所有计算的样式。

所以获取css属性时,要做一个兼容处理,可以封装一个函数,供其他时候使用.

function getStyle( obj,attr ){
    if( obj.currentStyle ){
        return obj.currentStyle[attr]
    }else{
        return getComputedStyle(obj)[attr];
    };
};

 

3.getComputedStyle与style的区别

getComputedStyle只可读,不可写;而element.style可读可写.

getComputedStyle方法获取的是最终应用在元素上的所有CSS属性对象,而element.style只能获取元素style属性中的CSS样式,即只能获取写在html标签中的写在style属性中的值(style=”…”),而无法获取定义在<style type=”text/css”>里面的属性.前面获取的对象范围大,后面的获取对象范围小.

 

4.getPropertyValue与getAttribute

getPropertyValue方法可以获取CSS样式申明对象上的属性值(直接属性名称).

比如我们在一个id为oDiv元素上加了一个float:left;那么我们用window.getComputedStyle(oDiv,null).getPropertyValue(“float”);它获取的就是left.

getPropertyValue()里面的书写形式不支持驼峰写法,如果想知道一个元素的层级,那么getPropertyValue("z-index"),而不能用zIndex代替.

不过在IE低版本里,用getPropertyValue()会报错,这时IE可以用style.getAttribute(),这里属性名需要驼峰写法.

时间: 2024-08-09 10:04:17

20151211小问题的相关文章

微信小程序--图片相关问题合辑

图片上传相关文章 微信小程序多张图片上传功能 微信小程序开发(二)图片上传 微信小程序上传一或多张图片 微信小程序实现选择图片九宫格带预览 ETL:微信小程序之图片上传 微信小程序wx.previewImage预览图片 微信小程序之预览图片 小程序开发:上传图片到腾讯云 .NET开发微信小程序-上传图片到服务器 微信小程序本地图片处理--按屏幕尺寸插入图片 [微信小程序]上传图片到阿里云OSS Python Flask小程序文件(图片)上传技巧 小程序图片上传阿里OSS使用方法 微信小程序问题汇

微信小程序——豆瓣电影——(2):小程序运行部署

Demo 预览 演示视频(流量预警 2.64MB) GitHub Repo 地址 仓库地址:https://github.com/zce/weapp-demo 使用步骤 将仓库克隆到本地: bash $ git clone https://github.com/zce/weapp-demo.git weapp-douban --depth 1 $ cd weapp-douban 打开微信Web开放者工具(注意:必须是0.9.092300版本) 必须是0.9.092300版本,之前的版本不能保证正

微信小程序开发初探

一.关于微信小程序 1.1 小程序诞生的背景 张小龙说道: (1)一切以用户价值为依归→用户是微信的核心,所以微信中没有很多与客户无关的功能,比如QQ中的乱七八糟一系列东西. (2)让创造发挥价值→所有围绕微信的创造比如公众号都应该发挥其应有的价值. (3)用完即走的高效服务→这一点就厉害了word天,微信要打造一个以微信为中心的生态链,不以绑定用户为目标.比如生活中有一些不太常用的app,我们可能一年也使用不了几次,但是有时候就需要用到,微信就想要提供这样一个平台,让你可以在微信中使用这中所谓

微信小程序连接Tornado

自己搭建Tornado 监听8000端口, 提供给小程序访问的地址为http://127.0.0.1:8000/index #!/usr/bin/env python # -*- coding:utf-8 -*- import tornado.ioloop import tornado.web class MainHandler(tornado.web.RequestHandler): def get(self): print('GET方式请求成功') self.write("123"

【小程序】获取微信 自带的 收货地址获取和整理

1.wx.chooseAddress(OBJECT) if(wx.chooseAddress){ wx.chooseAddress({ success: function (res) { console.log(JSON.stringify(res)) }, fail: function(err){ console.log(JSON.stringify(err)) } }) }else{ console.log('当前微信版本不支持chooseAddress'); } 2.数据处理,仅供参考 /

微信小程序学习总结(2)------- 之for循环,绑定点击事件

最近公司有小程序的项目,本人有幸参与其中,一个项目做下来感觉受益匪浅,与大家做下分享,欢迎沟通交流互相学习. 先说一下此次项目本人体会较深的几个关键点:微信地图.用户静默授权.用户弹窗授权.微信充值等等. 言归正传,今天分享我遇到的关于wx:for循环绑定数据的一个tips:  1. 想必大家的都知道wx:for,如下就不用我啰嗦了: <view class="myNew" wx:for="{{list}}">{{item.title}}<view

微领地小蜜app模式系统开发详解

如今企业竞争的最高境界, 不再是产品的竞争.人才的竞争.营销的竞争-- 而是一种商业模式(即赢利模式)的竞争. 微领地小蜜软件,微领地小蜜系统,小蜜APP,微领地小蜜平台,微领地小蜜开发公司,微领地小蜜服务模式,微领地小蜜商圈.O2O.C2B.B2C.F2C.B2B.C2N.C2C等微商城.App.手机网页.PC商城.小程序,微商管理系统.一物一码.防伪防窜.扫码红包.质量追溯.分销.全返.分红.拼团.互联网+直播+定制服务·系统开发提供中心. 回首过去,创新与发展裹带着机遇和挑战,微领地小蜜在

手机上也可以用的快手和火山小视频提取工具

之前分享过一个火山无水印视频提取软件,但是需要安装到电脑上,很多人觉得很麻烦. 今天分享个网页版,无需安装,并且电脑和手机都可以用的视频提取工具,支持提取快手和火山小视频里的任何视频,就连火山小视频里那种<作者不允许他人下载>的视频都可以解析,并且解析出来的视频都是没有水印的.(是不是觉得这工具特别赞,觉得赞的话,给我的文章点个赞吧??) 工具地址: 快手视频解析下载:http://kuaishou.iiilab.com/ 火山小视频解析下载:http://huoshan.iiilab.com

自制linux小系统

自制linux 今天说一说怎么自制一个linux,也就是用一块新硬盘来自己搞一个linux.硬盘拆掉撞到其他机器上可以照常使用,需要什么东西都是自己添加的哦. 那我就在虚拟机里进行了嘿嘿嘿... 1.在我的centos里加了一块新的硬盘并顺便分了个区,并且格式化了一下. [[email protected] ~]# fdisk /dev/sdb WARNING: DOS-compatible mode is deprecated. It's strongly recom mended to