How to put text over an image without absolute positioning or setting the image as backbround

前端 未结 6 2044
死守一世寂寞
死守一世寂寞 2020-12-05 05:49

I\'m trying to see if it is possible to put some text over an image without using position: absolute or having the image being, the background of an element.
The reason

相关标签:
6条回答
  • 2020-12-05 05:56

    I used to pull stunts like this all the time as soon as tables came. Really ugly, and may seriously embarrass any validator you run it trough: overlapping table cells. Works in most browsers though and even without css.

    Example:

    <table>  
      <tr>
        <td></td>
        <td rowspan=2><img src="//i.stack.imgur.com/XlOi4.png"></td>
      </tr>  
      <tr>
        <td colspan=2>This is the overlay text</td>
      </tr>  
    </table>

    I know, I deserve a downvote for this.

    0 讨论(0)
  • 2020-12-05 06:00

    You can try setting negative margins. This is very difficult to maintain in all but the least complex layouts. A negative margin effective "pulls" the element in that direction.

    <img src="blah.jpg" height="100"/>
    <div style="margin-top:-100px">
      blah blah blah
    </div>
    
    0 讨论(0)
  • 2020-12-05 06:12

    say if you have a parent div and an image and paragraph inside it, give position "relative" to all three of them, and give "z-index" to children, say "20" image and and "21" to Text. the text will appear over the image. and you can adjust the text with "top or left or right or bottom"

    CSS
    #learning{
    margin: 0px;
    padding:0px;
    height: auto;
    width: 100%;
    position: relative;
    
    }
    #learning>img{
    width:inherit;
    height:inherit;
    margin: 0px;
    display: block;
    position: relative;
    z-index: 20;
    }
    #learning > p{
    font-family: 'droid_serifitalic';
    color: white;
    font-size: 36px;
    position: relative;
    top:470px;
    left:500px;
    z-index: 21;
    } 
    
    0 讨论(0)
  • 2020-12-05 06:20

    The best way to control the look of things would be to make the text part of the image itself. Of course, if you use a lossy image format like jpeg with high compression it could look really bad, but maybe a PNG will work for you? Or, depending on the number of colors, a gif might work.

    This also gives you consistent-looking fonts, filtering, etc.

    0 讨论(0)
  • 2020-12-05 06:20

     .main_image{grid-area: overflow;}
    
        .main_text{
        grid-area:overflow;
        color: white;
        margin: auto auto auto 5%;
        font-size: 2rem;
        line-height: 3rem;} 
        .main{
        display: grid;
        grid-template-columns: 1fr;
        grid-template-rows:1fr; 
        grid-template-areas: "overflow";
        }
        <div class="main">
    			
          <div class="main_image">
             <img src="https://images.unsplash.com/photo-1548783300-70b41bc84f56?ixlib=rb-1.2.1&ixid=eyJhcHBfaWQiOjEyMDd9&auto=format&fit=crop&w=334&q=80" style="width:100%; height:auto">
           </div>
    
           <div class="main_text"> 
                <p>overlap text</p>
                <h2>your text</h2>
                <p>lorem ipsum lorem lorem</p>
           </div>  
       </div>
       

    0 讨论(0)
  • 2020-12-05 06:21

    If you use absolute positioning, you should specify both the left and top attributes. Also, you should set position:relative; on some parent element to make it a layer, so that the absolute positioning uses that element as origin. If you don't specify the origin, it may be the window or it may be some other element, and you don't know where your absolutely positioned element will end up.

    There are some other alternatives to place elements on top of each other, each with their own limitations.

    You can use relative positioning to make text display on top of an image:

    <img src="..." alt="" />
    <div style="position:relative;top:-50px;">
       This text will display 50 pixels higher than it's original position,
       placing it on top of the image. However, the text will still take up
       room in it's original position, leaving an empty space below the image.
    </div>
    

    You can use a floating element inside another element to put text on top of an image:

    <div>
       <div style="float:left;">
          This text will be on top of the image. The parent element
          gets no height, as it only contains floating elements.
          However, IE7 and earlier has a bug that gives the parent
          element a height anyway.
       </div>
    </div>
    <img src="..." alt="" />
    
    0 讨论(0)
提交回复
热议问题