What is reactive? Responsive pages have different layouts on different screens; in other words, the same HTML has different layouts at different resolutions. As shown below:


There are three solutions for traditional mobile terminal adaptation. The first is the columns layout of bootstrap. The second method is to use global REM, first convert the number of PX for 1rem according to the screen, and then set the font size of THE HTML tag to the number of REM. The larger the screen is, the larger the font size is, and then all the elements of the page are scaled by REM and other proportions. The third is Alibaba’s Flex Box, which is similar to the second, except that the font size of the page content is PX instead of rem scaled. The first requires the introduction of an additional framework. The third is more reasonable than the second, because text text is usually 14px or 16px, and if one page is 15.5px on one phone and 14.9px on another, it might be a bit weird.

While reactive layouts do not require REM conversion, here is a step-by-step analysis of how to do reactive layouts using the example shown above.

1. Set white space on both sides of the page with different resolutions

First, the body of a page has a maximum width. When the screen exceeds this width, the body in the middle is this big and doesn’t get any bigger. That is, it has a fixed maximum width and is then centered, such as 1080px. Then, when it is larger than 1024px, the minimum width of the main content of the page is 960px, and the two sides are automatically blank. Leave 40px on both sides between 500px and 1024px; If it is less than 500px, it will be considered a mobile phone and leave 20px white on both sides. So calculate the container code as follows:


2. As the screen gets smaller, one end gets narrower and the other stays the same

When the screen gets smaller or the browser window pulls down, the content in the middle can’t stay 1080px wide, it has to get smaller, and as it gets smaller, it tends to keep one side the same and the other side narrower with the page, as shown below:


3. Keep the middle blank fixed and reduce the content width

How do I make the left column smaller? As a rule, keep the spacing in the middle constant and the width of the content on both sides narrow accordingly, as shown below:


input{
    width: calc((100% - 20px) / 2)}Copy the code

Calc compatibility IE10 and above support, Android 4 and below does not support, so to consider the unsupported devices, can simply make a compatibility, as shown in the following code:

input{
    width: 48%;
    width: calc((100% - 20px) / 2);
}Copy the code

If calC is not supported, 48% is used, so the difference is not very large, or not very precise. If you really need to, you can write a few more media queries to be more precise.

4. Change the left/right layout to the up/down layout

When the screen is pulled too small, the left column is already too small, and any smaller is incongruous, so change the layout from left to right to up and down, and put the content on the right down. Since the right column is float: right on the large screen, it overrides the float property on the medium screen and changes to float: None. The right column originally had four short lines. Consider floating the three lines below it. As shown in the following code:

.cal-result{
    float: right;
    width: 330px;
}

@media (max-width: 800px) {.cal-result{
        float: none;
        width: 100%;
    }
    .cal-result .result{
        float: left;
        width: 33%; }}Copy the code

Make each result equal to 1/3 and float it as follows:

5. If the width is too small, wrap it

Especially if the content is in the ul form of the list, the li that does not fit should be automatically moved to the next line. Of course, it can also be manually controlled as follows:

@media (max-width: 800px) {.result{
        width: 33%; }} @media (max-width: 400px) {.result{
        width: 50%; }}Copy the code

At a screen width of less than 400, each result counts for 50%, which makes two rows. This is also a common method, but in our example, if the numbers are small, they will fit well on the iPhone6’s 375px screen, and will look better if they stay in one line. And it’s fixed at 50%, so if you have a big number, there’s a risk of overlap, so there’s a way to do that, you don’t have to kill the width, you have to kill the min-width at 50%, so that if you have a long number, float elements that don’t fit on the same line will wrap. But it’s best to have a way to wrap it according to the length of the content. You can use JS, but it’s a bit of a hassle.

This is where Flex comes in. It’s as simple as setting two properties:

.result-container{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}Copy the code

Space-between sets the child elements equally spaced on both sides of the container, while the wrap attribute wraps the child elements automatically. This has the following effect when the container is not large enough:



.result:not(:last-child) {
    margin-right: 10px;
}Copy the code

The effect is as follows:


In addition, when changing from a large screen to a small screen, some font sizes are mainly the font size and spacing of the title should be adjusted accordingly. This kind of smaller font size is a step change, rather than a continuous change like REM, and this kind of ladder is generally enough as long as there are two, a large screen and a small screen. If you have to make a lot of stairs, you probably have a typography problem.

6. Use responsive images

For the same header image, a large image is needed on the computer, but it is better to use a small image on the mobile phone, otherwise it will cause problems such as slow loading and waste of traffic on the mobile phone. One solution is to use Backound-image combined with media query, as shown below:

.banner{
    background-image: url(/static/large.jpg);
}

@media (max-width: 500px){
    background-image: url(/static/small.jpg);
}Copy the code

The downside of this approach is that it’s not SEO friendly because you can also write an Alt attribute if you use the IMG tag. The second common way to do this is to use the IMG srcset or Picture tag for responsive images, which I mentioned in Effective Front End 7 and won’t repeat here.

In addition to large and small screens, this kind of responsive image can also take into account the screen with DPR of 2 or above and the screen with DPR of 1, that is, the screen with high DPR uses 2x image while the screen with 1x image.

7. Other issues

In some areas, the layout of the large and small screens is quite different. For example, if the content is placed next to each other on a large screen and the content is placed far away from each other on a small screen, you may have to duplicate the HTML, write two tags, hide the smaller HTML tags on a large screen, and hide the larger HTML tags on a small screen. And this shouldn’t be the case all the time. If you often have to write two sets of pages, your page is probably not a good place to write reactive ones, so you might as well write two sets of pages.

There is another problem, sometimes you might want to use REM/Transform: Scale to scale, but this is always a bad idea. The rule is to keep the size and spacing constant when the screen span is not very large. The effect of using the transform is that when the screen is pulled down, the content becomes smaller, but since the transform doesn’t rearrange, it still occupies the same height, and the following content doesn’t follow. You have to manually calculate the height of the content. Also, if you use REM, it conflicts with the idea of responsiveness. If part of the page is REM and part of the page is PX, it’s not compatible, and you don’t need responsive development if you write all REM. At this point you might want to wonder if there’s something wrong with the UI. Let the UI recalibrate.

In addition, sometimes the height of media queries may be used, for example, when the height is less than how much, do not let the popbox beyond the height of the page; When the height is greater than what, make the footer fixed at the bottom, otherwise the footer may be left blank.

Finally, this paper summarizes some ideas of responsive development, its advantages are not large screen to write a set, small screen to write a set, convenient maintenance, shorten the development time, the disadvantage is compatibility is not particularly good, and the effect is not dedicated to a small screen UI and interaction as good. But overall, there are advantages to being responsive, and it looks good on a small screen, as long as it’s well designed. Now responsive development is becoming more and more popular, it can be compatible with PC/Pad/ mobile screen, this advantage is unbeatable, you just need to write a set of HTML and a set of JS logic, no matter how big the screen.