
首先需要知道如何获取屏幕的宽高
对于19201080的电脑屏幕
1、获取窗口中的文档显示区域宽高
w = windowinnerWidth; //1920(包含滚动条)
h = windowinnerHeight; //883(不含工具条)
2、获取窗口(包括滚动条与工具条)区域宽高
w = windowouterWidth; //1920(包含滚动条)
h = windowouterHeight; //883(包含工具条)
3、获取网页可见区域宽高
clientw = documentbodyclientWidth; //1903(不包含滚动条)
clienth = documentbodyclientHeight; //866(不包含工具条)
4、获取网页可见(含边线,但不是边距)区域宽高
clientw = documentbodyoffsetWidth; //1903(不包含滚动条,含边线)
clienth = documentbodyoffsetHeight; //866(不包含工具条,含边线)
5、网页正文全文宽高
clientw = documentbodyscrollWidth; //1903(不含滚动条)
clienth = documentbodyscrollHeight; //1269(不含工具条)
所谓正文全文,实际就是整个网页文档的宽高,既然是整个网页文档宽高肯定就是,网页内容有多宽那个宽就是多少,网页内容有多高那高就是多少了,当然同样包含着边线
6、屏窗
所谓屏窗就是整个屏幕窗口,我们前面说的到都属于视窗,也就是可视区域的窗口
获取屏窗一般使用:
clientw = windowscreenwidth; //1920
clienth = windowscreenheight; //1080
第二种是获取屏幕可用工作去宽高
clientw = windowscreenavailWidth; //1920
clienth = windowscreenavailHeight; //1040
原文链接: >
网页可见区域高:documentbodyclientHeight
网页可见区域高:documentbodyoffsetHeight (包括边线的宽)
网页正文全文高:documentbodyscrollHeight
网页被卷去的高:documentbodyscrollTop
屏幕分辨率的高:windowscreenheight
屏幕可用工作区高度:windowscreenavailHeight
在我们设计网页的时候,经常会遇到自适应问题,实际这些工作完全可以交给浏览器来完成就可以了,只可惜,无论是IE还是FIREFOX在自适应这个问题上都处理的不尽人意,网上实现网页宽度和高度的方法也很多,主要又两种:
第一种是使用CSS来完成;第二种是使用Javascript来完成,根据实际的应用效果来说,使用Javascript还是比较靠谱一点,因为CSS的expression的确有点烦,笔者是指使用效果上有点恼人,本文专门把这两种都总结一下,方便站长们参考使用。
一、使用CSS实现的自适应
使用CSS实现自适应很简单,主要靠两个参数来完成,分别是max-width和max-height,这两个参数在FIREFOX和IE7以上支持都很好,但是在IE6上面,效果非常糟糕,尤其是对于多张的显示,第一次显示网页大都很难达到自适应的效果,一般都是有些能自适应,有些不能自适应,多次刷新可能又显示OK,就是这点就足够烦人,而且一旦显示多张,IE6上就卡的要命(expression在IE上比较占用资源,感觉设计是用来玩得,FIREFOX自适应效果还是比较好,速度也非常快),反正笔者至今是没有找到更好的CSS方法来让IE6完美支持自适应。示例代码如下:
img{
max-width:128px;
max-height:128px;
height:auto;
zoom:expression(function(e){
if(ewidth>eheight){if(ewidth>128){eheight=eheight(128/ewidth);ewidth=128;}}
else{if(eheight>128){ewidth=ewidth(128/eheight);eheight=128;}}
estylezoom='1';}(this));
overflow:hidden;
}
上面代码格式上需要特别注意两点:
1、zoom属性里宽高赋值不能带单位(如px),否则无效;
2、if和else语句也必须带大括号括起来,单句指令也不行(而在很多编程语言里,单句指令可以无需大括号);
二、使用Javascript实现的自适应
使用Javascript自适应相对来说比较方便,唯一的麻烦是就是在网页中需要对image预设置onload事件处理resize()函数,如果对于动态网页来说还好一点,反正是动态的,程序里加上去就OK了,可是如果对于很多篇文章而言,在里头增加onload函数有点麻烦,除非一次性的写个脚本批量处理,否则后期更改或替换起来还是比较麻烦,比如的可显示宽度变化等等。
另一方面如果把宽度值写在Javascript中,那么将带来程序的通用性降低,下面的示例不是写死的,已测试效果比起CSS要HAPPY的多,网上也又很多类似的例子,不是不完成就是中间还存在某些问题,本文的例子应该会更好一点,笔者对不同的尺寸下的的显示效果做过好几种测试了。示例如下:
//RESIZE自适应宽度和高度
//参数说明:
//obj是对象,this调用方法见下面示例
//maxW和maxH分别为约定的最大宽度和最大高度
functionresizeimg(obj,maxW,maxH)
{
varimgW=objwidth;
varimgH=objheight;
if(imgW>maxW||imgH>maxH)
{
varratioA=imgW/maxW;
varratioB=imgH/maxH;
if(ratioA>ratioB)
{
imgW=maxW;
imgH=maxW(imgH/imgW);
}
else
{
imgH=maxH;
imgW=maxH(imgW/imgH);
}
objwidth=imgW;
objheight=imgH;
}
}
我们在制定宽度和高度值的时候,一般宽度是肯定需要限定,而高度经常不需要限制,所以可以把高度指定的大一点,如果高度也限制,那么相当于制定一个imagebox,下面的程序或许对您很有用(不限制高度的忽略下面这个示例)。
当指定BOX的时候,一般都还需要在自适应之后显示在BOX容器的中间,也就是水平和垂直都需要居中。首先需要指定BOX容器的宽度和高度,然后可以使用CSS来控制显示效果,也可以使用Javascript控制显示效果。示例如下:
CSS显示方法如下:
#imgbox{text-align:center;vertical-align:middle;}
#imgboximg{vertical-align:middle;}
或使用Javascript完成:
在上文resizeimg()函数里最后只需要增加类似这样的语句,
objstylemargin-left=(800-imgW)/2;
objstylemargin-top=(800-imgH)/2;
即可,当然了,您总不能让resize尺寸本来就超出BOX容器尺寸吧,否则就把容器撑大,style风格肯定就对不上了。
vue给的1360的图写页面做到自适应步骤如下:
1vue在设置好的div里面自动适应宽高,显示全部,不够宽高的留空白;
2本文使用的分辨率为:4000x2026;
3我的电脑分辨率为:1920x1080;
4默认宽高如果设置100%,电脑屏幕会显示不全的;
5注意:这里设置了最高 高度为700,如果高度太高,会显示不全;
6访问页面,电脑屏幕就可以完整的显示了。
页面里被查找的元素添加一个 ref='refrence' 这里refrencce可以随便起名字,下面引用这个名字
然后要获取这个元素就用this$refsrefrence
同样,组件添加到页面里的内容也可以通过添加ref标签来获组件里内容
比如获取元素高度
this$refselementoffsetHeight
比如:改变元素的高 那么这个height必须要在这个div写样式的时候就已经有了,否则无法获取到
以上就是关于笔记:轮播图大小随不同分辨率电脑等比例放大缩小(vue)全部的内容,包括:笔记:轮播图大小随不同分辨率电脑等比例放大缩小(vue)、css获取整个页面高度、网上实现网页图片宽度和高度的方法等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)