For front-end developers, to deal with this problem, they must first add a knowledge point, that is, physical pixels [device pixels] & logical pixels [CSS pixels]; In another piece of my article, I introduced the 100% reduction of the design draft. Interested friends can check it.
Why 1px is it getting thicker?
why is 1px written in the CSS of the mobile terminal, which actually looks thicker than 1px; Students who understand the physical pixels and logical pixels of the device should be easy to understand. In fact, the meanings of these two Pxs are different. The 1px required by the UI Designer refers to the physical pixel 1px of the device, while the pixels recorded in CSS are logical pixels. There is a proportional relationship between them. You can use the window in javascript Devicepixelratio can also be obtained by - WebKit min device pixel ratio of media query. Of course, the proportion is related to the equipment.
Border can't achieve the effect we want on the mobile phone. This is because of the devicePixelRatio feature. The devicePixelRatio of iPhone = = 2, and the border width: 1px describes the device independent pixels. Therefore, the border is enlarged to the physical pixel 2px, which appears thicker on the iPhone.
mobile terminal development often needs to add the following sentence to the html header:
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
this sentence defines that the width of the viewport on this page is the device width, the initial scaling value and the maximum scaling value are both 1, and user scaling is prohibited.
your question may come. You always see viewport. In addition to knowing the Chinese name viewport, what does it mean? In fact, it is the area on the device screen that can be used to display our web page content. Specifically, it is the part of the web page used by the webview in the browser or app. However, the viewport is not limited to the size of the browser's visual area, which may be large or small. Reflected in whether the user zoomed the screen.
careful students should feel that user scaling = no is often set in the meta tag, that is, user scaling is prohibited. What impact will user scaling have? In fact, it is a change in display. When you double the scale, the physical pixels represented by CSS pixels (logical pixels) will be doubled, that is, the ratio of device physical pixels to device independent pixels will be doubled (reduced).
maybe you already know the reason why 1px becomes thicker. The settings of viewport and screen physical resolution are proportional rather than the same The window object on the mobile terminal has a devicePixelRatio attribute, which indicates the ratio of physical pixels of the device to css pixels. On the iphone with retina screen, this value is 2 or 3. The 1px length written in css is as long as 2px or 3px when mapped to physical pixels.
How to solve 1px problems
1. Media query uses the device pixel ratio to scale and set decimal pixels
px values with decimals are supported under IOS8. The corresponding devicepixel ratio of media query has a query value - WebKit min device pixel ratio, which can be written in CSS
.border { border: 1px solid #999 } @media screen and (-webkit-min-device-pixel-ratio: 2) { .border { border: 0.5px solid #999 } } @media screen and (-webkit-min-device-pixel-ratio: 3) { .border { border: 0.333333px solid #999 } }
[disadvantages] there are requirements for equipment, and the compatibility of decimal pixels is poor at present.
2. viewport + rem scheme
this scheme is the optimization of the above scheme. The overall idea is to dynamically modify the scaling of the page by using viewport + rem + js to realize the display of less than 1 pixel. During page initialization, the original default state is introduced in the header as follows:
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8"> <meta name="viewport" id="WebViewport" content="initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no">
The next task is to dynamically modify the zoom ratio of js and set the font size of rem root element
var viewport = document.querySelector("meta[name=viewport]") if (window.devicePixelRatio == 1) { viewport.setAttribute('content', 'width=device-width, initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no') } if (window.devicePixelRatio == 2) { viewport.setAttribute('content', 'width=device-width, initial-scale=0.5, maximum-scale=0.5, minimum-scale=0.5, user-scalable=no') } if (window.devicePixelRatio == 3) { viewport.setAttribute('content', 'width=device-width, initial-scale=0.333333333, maximum-scale=0.333333333, minimum-scale=0.333333333, user-scalable=no') } var docEl = document.documentElement; var fontsize = 10 * (docEl.clientWidth / 320) + 'px'; docEl.style.fontSize = fontsize;
[disadvantages] it is considered that scaling involves the global rem unit, which is more suitable for new projects. For old projects, more changes may be involved.
3. Set the border image scheme
.border-image-1px { border-width: 1px 0px; -webkit-border-image: url("border.png") 2 0 stretch; border-image: url("border.png") 2 0 stretch; }
[explanation] border width specifies the width of the border. Four values can be set: top right bottom left.
Border image this example means that the border image is cropped 2px above the image (there is no unit on the attribute value) as the upper border and 2px below as the lower border. Cut the picture 0 pixels away from the left and right, that is, there is no border, and it is displayed in a stretched manner
The combination is: in the border picture, the width of 2 pixels at the top and bottom of the picture is cut as the upper and lower border, and displayed in the border space with the width of 1 pixel. There is no border on the left and right. Note that one pixel here is special, specifically referring to physical pixels, while the normally set length and width 1px represents logical pixels (this view is personal understanding).
you may not understand, what is the ghost of cutting borders? Why cut it? Border image is really a difficult attribute to understand. It's even more encircled after going w3c to see it. The content of w3c is too refined, but the explanation is not enough. Therefore, I present a detailed explanation of border image by Mr. Zhang Xinxu, especially to understand the nine palace lattice cutting method.
Of course, pictures are introduced in this way. We can also install pictures in base64 form
.border-image-1px { border-width: 1px 0px; -webkit-border-image: url("") 2 0 stretch; border-image: url('Above'); }
[disadvantages] pictures need to be made, and the rounded corners may be blurred
4. Background image gradient implementation
in addition to using pictures, you can also use pure css. Baidu glutinous rice group adopts this scheme.
.border { background-image:linear-gradient(180deg, red, red 50%, transparent 50%), linear-gradient(270deg, red, red 50%, transparent 50%), linear-gradient(0deg, red, red 50%, transparent 50%), linear-gradient(90deg, red, red 50%, transparent 50%); background-size: 100% 1px,1px 100% ,100% 1px, 1px 100%; background-repeat: no-repeat; background-position: top, right top, bottom, left top; padding: 10px; }
[idea] divide the border size of one physical pixel into several parts (percentage control) by linear gradient to achieve the effect of less than 1 pixel
[explanation] linear gradient specifies a linear gradient and accepts three parameters or more. The first is the gradient rotation angle, the second is the gradient color and the position (percentage) to which the gradient changes to the color. In this example, the first sentence is to rotate the gradient direction 180 degrees, that is, from top to bottom (0 degrees by default, from bottom to top), and from red, To 50% of the position is still red, and then the gradient inherits the color of the parent element.
[disadvantage] because each border is realized by linear gradient color, rounded corners cannot be realized
5. Box shadow scheme
Shadow can also be used. The advantage is that there is no fillet problem, and the disadvantage is that the color is not easy to control
div { -webkit-box-shadow: 0 1px 1px -1px rgba(0, 0, 0, 0.5); }
[understanding] let's review the usage of box shadow attribute.
box-shadow: h-shadow v-shadow [blur] [spread] [color] [inset];
The parameters respectively represent: horizontal shadow position, vertical shadow position, blur distance, shadow size, shadow color, changing external shadow to internal shadow, and the last four are optional. Why is the shadow size set to a negative number in this example? It is set to - 1px to make the shadow size slightly smaller than the div element size, so that the shadows on the left and right sides will not be exposed, so as to achieve the effect that only the bottom side has shadows. To achieve the split line effect (single side border)
6. transform: scale(0.5) scheme - Recommended: very flexible
in the above usages, there is no escape from the idea that 1px is reduced to 0.5px for display, however. 0.5px is not supported by all devices or browsers. Consider scaling it with media query or viewport. In fact, the 1-pixel problem basically occurs when setting the border or split line. The scene does not cover the global style. Therefore, we really need to directly scale the elements that need to be set. tranform can achieve this requirement.
Set height: 1px, and scale to the corresponding size according to the media query combined with transform.
div { height:1px; background:#000; -webkit-transform: scaleY(0.5); -webkit-transform-origin:0 0; overflow: hidden; }
2. Use:: after and:: befor to set border bottom: 1px solid #000, and then zoom WebKit transform: Scaley (0.5); It can meet the requirements of two sidelines
div::after{ content:'';width:100%; border-bottom:1px solid #000; transform: scaleY(0.5); }
3. Use:: after to set border: 1px solid #000; width:200%; height:200%, and then scale scaleY(0.5); The advantage is that rounded corners can be realized, which is how JD implements them. The disadvantage is that it is troublesome to add active buttons.
.div::after { content: ''; width: 200%; height: 200%; position: absolute; top: 0; left: 0; border: 1px solid #bfbfbf; border-radius: 4px; -webkit-transform: scale(0.5,0.5); transform: scale(0.5,0.5); -webkit-transform-origin: top left; }
6.5 optimization of scheme 1 by media query + transfrom
/* 2 Double screen */ @media only screen and (-webkit-min-device-pixel-ratio: 2.0) { .border-bottom::after { -webkit-transform: scaleY(0.5); transform: scaleY(0.5); } } /* 3 Double screen */ @media only screen and (-webkit-min-device-pixel-ratio: 3.0) { .border-bottom::after { -webkit-transform: scaleY(0.33); transform: scaleY(0.33); } }