Before getting into compatibility issues, take a look at the browser kernel. The most important and core part of the browser is the Rendering Engine, which translates as “Rendering Engine” but is commonly referred to as the “browser core”. It is responsible for parsing and rendering web pages. Different browser cores parse the syntax of web authoring differently, so the same page may render differently in different browsers with different cores, which is why web developers need to test web pages with different cores. Common browser kernels are :Trident (IE kernel), Gecko(Firefox kernel), Presto(Opera kernel, deprecated,Opera has now changed to Google Chrome Blink kernel) Webkit(Safari kernel,Chrome kernel prototype, open source), Blink(a browser typography engine developed by Google and Opera Software).


To put it simply, browser compatibility problems can be caused by the following reasons: 1. Since browsers are developed by various manufacturers, the kernel used (as mentioned above) is different from the core architecture and code. 2, for the consideration of their own interests, and set up a variety of technical barriers.



For example, the same code can be parsed differently in different browsers, resulting in a different display of the page. In most cases, our requirement is that no matter what browser the user uses to view our site or log in to our system, the display should be uniform.



So browser compatibility is a problem that front-end developers often encounter and must solve. Of course, browser compatibility not only refers to the CSS style parsing is not the same, there are many JS compatibility issues, today only said CSS compatibility issues. Fortunately for developers, compatibility issues will be less and less common as technology advances and browser standards become more uniform.


Fault 1: Labels of different browsers have different external and internal patches by default. For example, the margin and padding of several random tags will differ greatly without style control.

Start using * wildcards in CSS to clear the padding and margin values to 0;



Problem 2: Pictures have spacing by default. For example, some browsers have a default spacing when several IMG tags are placed together. Also, if the container is not set to height, the image will be stretched a few pixels larger at the bottom by default.

Workaround: Use the float property directly. Or use the vertical – align: top;



Problem 3: The transparency property is incompatible with Internet Explorer.

Solutions:

Filter :alpha(opacity=value); The value ranges from 1 to 100.

Opacity :0. Value; (value Indicates the value range

0-1 0.1,0.2,0.3—–0.9—1)



Problem 4: The picture has a blue border on Internet Explorer, if the picture is added to the A tag.

Img {border:0; }



Problem 5: Form elements are spaced inconsistently from the top.

Add a declaration to the form element: float:left;



Problem 6: In IE6 and below, when parsing percentages, they are rounded, resulting in 50% plus 50% greater than 100%.

Solution: Add a declaration to the float element on the right: clear:right;