为什么在火狐可以水平垂直居中,Chrome中就不行?_html/css_WEB-ITnose
代码如下,图片在火狐中可以水平居中,也可以垂直居中,但是在Chrome中只能垂直居中,不能水平居中。我搞了好久都找不到解决方法,大家帮我看看,谢谢了!
注:javascript:DrawImage(this, 300, 300) 是一个等比例缩小放大的函数。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><title>Test</title><script src="lib/js.js" type="text/javascript"></script><style type="text/css">#a{ width: 300px; height: 300px; margin: 10px; display: table-cell; border: 1px solid red; text-align: center; vertical-align: middle; overflow: hidden;}#b{ width: 300px; height: 300px; padding: 2px; display: table-cell; border: 1px solid #DDDDDD; vertical-align: middle; text-align: center;}</style></head><body><div id="a" > <a href="#"><img src="/static/imghw/default1.png" data-src="1.jpg" class="lazy" onload="javascript:DrawImage(this, 300, 300)" / alt="为什么在火狐可以水平垂直居中,Chrome中就不行?_html/css_WEB-ITnose" ></a></div><div id="b"> <img src="/static/imghw/default1.png" data-src="1.jpg" class="lazy" onload="javascript:DrawImage(this, 300, 300);" / alt="为什么在火狐可以水平垂直居中,Chrome中就不行?_html/css_WEB-ITnose" ></div></body></html>
回复讨论(解决方案)
这个应该是居中的 楼主可以把img给定宽度试试
你的js函数有问题吧。。
测试了再chrome 25.0.1364.172 m下没问题,就直接用css控制了下长宽
#a img ,#b img{width:200px;height:200px}
你的js函数有问题吧。。
测试了再chrome 25.0.1364.172 m下没问题,就直接用css控制了下长宽
#a img ,#b img{width:200px;height:200px}
函数应该没问题的,如下:
//图片按比例缩放var flag=false;function DrawImage(ImgD, w, h){var image=new Image();var iwidth = w; //定义允许图片宽度,当宽度大于这个值时等比例缩小var iheight = h; //定义允许图片高度,当宽度大于这个值时等比例缩小image.src=ImgD.src;if(image.width>0 && image.height>0){ //假如图片长宽都不为零flag=true; if(image.height/image.width>= iheight/iwidth){ //通过正弦值判断图片缩放后是否偏高 if(image.height>iheight){ //如果图片比设定的要高 ImgD.height=iheight; ImgD.width=(image.width*iheight)/image.height; }else{ ImgD.width=image.width; ImgD.height=image.height; } ImgD.alt=image.width+"×"+image.height; } else{ //如果图片比例 小于 设定的比例 if(image.width>iwidth){ ImgD.width=iwidth; ImgD.height=(image.height*iwidth)/image.width; }else{ ImgD.width=image.width; ImgD.height=image.height; } ImgD.alt=image.width+"×"+image.height; }} ImgD.style.display = "table-cell";}
你的js函数有问题吧。。
测试了再chrome 25.0.1364.172 m下没问题,就直接用css控制了下长宽
#a img ,#b img{width:200px;height:200px}
这个js函数又没有控制css样式。
这个你测试到底是不是js函数引起的,直接把js函数删掉,然后看看是不是能居中,就知道了。
并且,你这个函数里面就是在修改宽度和高度,你竟然说没有控制CSS样式。。。
这个你测试到底是不是js函数引起的,直接把js函数删掉,然后看看是不是能居中,就知道了。
并且,你这个函数里面就是在修改宽度和高度,你竟然说没有控制CSS样式。。。
测试了下,是这个函数的问题,可是这个函数只修改了图片高度和宽度,没有设置对齐方式啊,为什么图片水平居不了中呢。在不改变函数功能的前提下,这个函数该怎么改呢?谢谢!
ImgD.style.display = "table-cell";
把最后面的这个去掉试试吧。
#a>a,#b>img{ display:inline-block;}
ImgD.style.display = "table-cell";不要了
ImgD.style.display = "table-cell";
把最后面的这个去掉试试吧。
这样可以了,谢谢!
不过我还是想问下为什么表格单元内的表格单元不能水平居中呢?
即外层div是table-cell,内层图片是table-cell,这样就不能水平居中。好奇而已。
我的问题解决了,谢谢大家!
我对这个不是太理解
你可以这么认为,display是作用于是用的标签本身的,是让它和table中的td一样的样式,而通常呢,td都是居左显示的,左边或者是table的左边界,或者是上一个兄弟td。所以,你这里设置了table-cell之后,img就去居左了。
可以举个简单的例子:
<div style = "border:1px solid #aaa;width:500px;height:400px;"> <div style = "width:200px;height:200px;margin:0 auto;background:#eee;"> </div></div>
这里,内部的那个div是居中显示的。
如果你在里面再加个display:tabel-cell试试看,它就居左了。。。
可能说的不是这个情况产生的最根本原因,因为没怎么用过这个属性。。。
可以去搜一下,是不是有这方面的文章,看看~~
你理解的优点错误哦。。。
display这个属性,只会对本身有影响,后代是不会继承的
你本身的display不管设置成什么样子,都不会对它后代的显示方式有影响的。
所以,你这里的原因,只是因为img设置了display=table-cell,跟父元素设置了display=table-cell,没有一点关系的。
你理解的优点错误哦。。。
display这个属性,只会对本身有影响,后代是不会继承的
你本身的display不管设置成什么样子,都不会对它后代的显示方式有影响的。
所以,你这里的原因,只是因为img设置了display=table-cell,跟父元素设置了display=table-cell,没有一点关系的。
但是img设置了table-cell后再设置text-align: center;都不起作用。
http://www.w3school.com.cn/css/pr_text_text-align.asp
text-align一般是用于处理文字的(后代会继承该属性),并且,这个是对子元素设置的效果,说是对子元素,其实也包括该元素包含的文字,但有一点是肯定,它对它本身是没有影响的。而display正好相反,display只对设置的元素本身有影响,并且后代不会继承。
一般情况下,text-align:center不会让子标签中的块级元素显示为居中的,比如,行内元素会被居中处理。这里img是属于行内元素的表现类型,所以才会居中。
display中,只有“inline”和“inline-***”开头的属性是属于行内元素的,而table开头的属性,都是被解析成块级元素的。
好像说的差不多了。。
给你个例子,还是在上面例子的基础上修改的。
<div style = "border:1px solid #aaa;width:500px;height:400px;text-align:center;"> <div style = "width:300px;height:300px;background:#eee;"> <img src = "#" style = "width:100px;height:100px;" alt="为什么在火狐可以水平垂直居中,Chrome中就不行?_html/css_WEB-ITnose" ></img> <img src = "#" style = "width:100px;height:100px;display:table-cell;" alt="为什么在火狐可以水平垂直居中,Chrome中就不行?_html/css_WEB-ITnose" ></img> </div></div>
你在浏览器调试工具中可以查看每个标签的CSS样式,应该可以看到:
1:最外层的div,设置了text-align,会被所有的子元素继承了,但是它的子元素中,块级元素div,并没有居中。
2:第二层的div,同样继承了text-align,它的子元素中,有两个img标签,第一个img没有设置display属性,那么其默认属性就是行内元素,这个img居中了;第二个img设置了table-cell属性,被当做了块级元素,那么这个img的前后,就会有换行符,所以,这个元素并没有能和第一个img并排显示,而是另起一行显示。并且没有居中。
这样应该可以大概明白了吧?
http://www.w3school.com.cn/css/pr_text_text-align.asp
text-align一般是用于处理文字的(后代会继承该属性),并且,这个是对子元素设置的效果,说是对子元素,其实也包括该元素包含的文字,但有一点是肯定,它对它本身是没有影响的。而display正好相反,display只对设置的元素本身有影响,并且后代不会继承。
一般情况下,text-align:center不会让子标签中的块级元素显示为居中的,比如,行内元素会被居中处理。这里img是属于行内元素的表现类型,所以才会居中。
display中,只有“inline”和“inline-***”开头的属性是属于行内元素的,而table开头的属性,都是被解析成块级元素的。
好像说的差不多了。。
给你个例子,还是在上面例子的基础上修改的。
<div style = "border:1px solid #aaa;width:500px;height:400px;text-align:center;"> <div style = "width:300px;height:300px;background:#eee;"> <img src = "#" style = "width:100px;height:100px;" alt="为什么在火狐可以水平垂直居中,Chrome中就不行?_html/css_WEB-ITnose" ></img> <img src = "#" style = "width:100px;height:100px;display:table-cell;" alt="为什么在火狐可以水平垂直居中,Chrome中就不行?_html/css_WEB-ITnose" ></img> </div></div>
你在浏览器调试工具中可以查看每个标签的CSS样式,应该可以看到:
1:最外层的div,设置了text-align,会被所有的子元素继承了,但是它的子元素中,块级元素div,并没有居中。
2:第二层的div,同样继承了text-align,它的子元素中,有两个img标签,第一个img没有设置display属性,那么其默认属性就是行内元素,这个img居中了;第二个img设置了table-cell属性,被当做了块级元素,那么这个img的前后,就会有换行符,所以,这个元素并没有能和第一个img并排显示,而是另起一行显示。并且没有居中。
这样应该可以大概明白了吧?
非常感谢,谢谢你耐心的解答!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











공식 계정 웹 페이지 업데이트 캐시, 이것은 간단하고 간단하며 냄비를 마시기에 충분히 복잡합니다. 공식 계정 기사를 업데이트하기 위해 열심히 노력했지만 사용자는 여전히 기존 버전을 열었습니까? 이 기사에서는이 뒤에있는 비틀기와 회전을 살펴 보고이 문제를 우아하게 해결하는 방법을 살펴 보겠습니다. 읽은 후에는 다양한 캐싱 문제를 쉽게 처리 할 수있어 사용자가 항상 가장 신선한 콘텐츠를 경험할 수 있습니다. 기본 사항에 대해 먼저 이야기 해 봅시다. 액세스 속도를 향상시키기 위해 브라우저 또는 서버는 일부 정적 리소스 (예 : 그림, CSS, JS) 또는 페이지 컨텐츠를 저장합니다. 다음에 액세스 할 때 다시 다운로드하지 않고도 캐시에서 직접 검색 할 수 있으며 자연스럽게 빠릅니다. 그러나 이것은 또한 양날의 검입니다. 새 버전은 온라인입니다.

이 기사는 CSS를 사용한 웹 페이지에 효율적인 PNG 테두리 추가를 보여줍니다. CSS는 JavaScript 또는 라이브러리에 비해 우수한 성능을 제공하며, 미묘하거나 눈에 띄는 효과를 위해 테두리 너비, 스타일 및 색상 조정 방법을 자세히 설명합니다.

이 기사에서는 브라우저에서 직접 사용자 입력을 검증하기 위해 필요한, Pattern, Min, Max 및 Length 한계와 같은 HTML5 양식 검증 속성을 사용하는 것에 대해 설명합니다.

이 기사는 HTML & LT; Datalist & GT에 대해 논의합니다. 자동 완성 제안을 제공하고, 사용자 경험을 향상시키고, 오류를 줄임으로써 양식을 향상시키는 요소. 문자 수 : 159

기사는 HTML5 크로스 브라우저 호환성을 보장하기위한 모범 사례에 대해 논의하고 기능 감지, 점진적 향상 및 테스트 방법에 중점을 둡니다.

이 기사는 HTML & lt; meter & gt에 대해 설명합니다. 범위 내에 스칼라 또는 분수 값을 표시하는 데 사용되는 요소 및 웹 개발의 일반적인 응용 프로그램. & lt; meter & gt; & lt; Progress & Gt; 그리고 Ex

이 기사는 HTML & lt; Progress & Gt에 대해 설명합니다. 요소, 그 목적, 스타일 및 & lt; meter & gt의 차이; 요소. 주요 초점은 & lt; progress & gt; 작업 완료 및 & lt; meter & gt; Stati의 경우

이 기사는 html5 & lt; time & gt; 시맨틱 날짜/시간 표현 요소. 인간이 읽을 수있는 텍스트와 함께 기계 가독성 (ISO 8601 형식)에 대한 DateTime 속성의 중요성을 강조하여 Accessibilit를 향상시킵니다.
