首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Can I use?
http://caniuse.com/
Less
http://lesscss.org
Cool Libraries
Bootstrap from Twitter
Jetstrap
Coding
V2EX  ›  CSS

有办法去掉从父级元素继承下来的 CSS 样式吗?

  •  
  •   wincat · 2015-01-30 12:02:06 +08:00 · 46269 次点击
    这是一个创建于 1778 天前的主题,其中的信息可能已经有所发展或是发生改变。

    有一个页面使用了 Bootstrap,父级用了container类,我想让里面的一个div宽度扩展到屏幕一样,肿莫破?

    第 1 条附言  ·  2015-01-30 14:18:20 +08:00
    
    56 回复  |  直到 2015-01-31 11:00:55 +08:00
        1
    iamcho   2015-01-30 12:11:28 +08:00
    在div里给它加上一个类,给新加的类写样式
        2
    Biwood   2015-01-30 12:12:41 +08:00   ♥ 1
    想办法使div脱离文档,然后宽度设为100%
        3
    yushiro   2015-01-30 12:13:30 +08:00 via iPhone   ♥ 1
    用!important覆盖继承的样式
        4
    kisshere   2015-01-30 12:15:45 +08:00 via Android
    在HTML里面写style=""
        5
    superbear   2015-01-30 12:19:18 +08:00
    离他越近,越靠后的类优先级越高,可以覆盖
        6
    jarlyyn   2015-01-30 12:22:52 +08:00
    重写样式。放在更靠后的位置。加入更多的类限制。

    不过觉得你的问题和是否继承无关的样子。
        7
    jarlyyn   2015-01-30 12:23:28 +08:00
    @kisshere 这个没用吧?
        8
    scarlex   2015-01-30 12:32:48 +08:00
    @jarlyyn 有用,html 里面的的 style 优先级最高
        9
    iinterest   2015-01-30 12:40:21 +08:00
    不能去掉,但可以写个新的覆盖,覆盖规则可以搜索『CSS 特殊性』
        10
    cxshun   2015-01-30 12:40:44 +08:00
    @jarlyyn 有用的,style优先级最高。
        11
    learnshare   2015-01-30 12:40:45 +08:00
    你这个问题不是改 CSS 来解决,是需要改 HTML 结构解决
        12
    jarlyyn   2015-01-30 12:53:54 +08:00 via Android
    @cxshun 可以去掉所有样式?
        13
    66beta   2015-01-30 12:57:57 +08:00
    既然使用BS,就遵循它的设计理念,改HTML结构吧

    懒就写CSS覆盖
        14
    cxshun   2015-01-30 12:59:33 +08:00
    @jarlyyn 这个当然不行,只能覆盖你配置的那个样式。其实上就类似了你在CSS块里面写的!import这种。
        15
    loading   2015-01-30 13:11:36 +08:00
    加上 id ,在css 里写就行,id 看上去比写 style 那个些。。。
        16
    momou   2015-01-30 13:18:03 +08:00
    这样如何?
    .container>row{
    width: 166.67%;
    margin-left: -33.33%;
    }
        17
    juicy   2015-01-30 13:19:00 +08:00
    css的强行继承真是广为诟病,难怪facebook那些人一直在抱怨css是个让人头疼的东西~
        18
    learnshare   2015-01-30 13:20:34 +08:00
    用 CSS 解决这个问题,就是在挖更大的坑。不应该用 Bug 解决 Bug
        19
    wincat   2015-01-30 13:24:57 +08:00
    @learnshare 你说的对,我也了解,但项目已经差不多了,想找个捷径处理。
        20
    wincat   2015-01-30 13:26:08 +08:00
    @momou 这样页面就会莫名其妙的变宽了,左右拖动就发现有问题了。
        21
    wincat   2015-01-30 13:27:23 +08:00
    @66beta 其他地方还是要用BS的,只是少数几个地方要这样处理。
        22
    tension   2015-01-30 13:29:38 +08:00
    给 <body class="action">

    当前的action 加上class 然后自己单独写

    比如 .home . container
        23
    wincat   2015-01-30 13:30:37 +08:00
    @kisshere 试试看
        24
    wincat   2015-01-30 13:34:04 +08:00
    @kisshere 没有用的
        25
    muzuiget   2015-01-30 13:34:10 +08:00
        26
    wincat   2015-01-30 13:35:51 +08:00
    @tension 大部分地方我还是要使用BS,而且我是用ajax做的单页面,所以这么改好像不是很妥。
        27
    be1mont   2015-01-30 13:40:03 +08:00
    style="padding:0;margin:0;"
        28
    wincat   2015-01-30 13:42:31 +08:00
    @be1mont 木有用滴
        29
    learnshare   2015-01-30 13:44:48 +08:00
    @wincat 为了以后挖坑...
        30
    wincat   2015-01-30 13:50:12 +08:00
    @muzuiget 没看懂,还是我用错了,没有效果。
        31
    loading   2015-01-30 13:54:43 +08:00
    似乎你是因为它的父级元素宽度限制?
    如果不改html,那么应该 position:absolute ,然后就更麻烦了。。。

    建议你还是改html
        32
    loading   2015-01-30 13:55:53 +08:00
    建议上个demo,方便大家改
        33
    jarlyyn   2015-01-30 13:58:13 +08:00
    前端页面无非3条路。
    html,css,js。
    你的需求理论上要改html最好。不然的话就用js直接操作dom呗……
        34
    be1mont   2015-01-30 13:59:23 +08:00
    @wincat 在container上 把 padding 和margin 弄成0
        35
    wincat   2015-01-30 14:20:43 +08:00
    @jarlyyn html结构改掉应该是正道,但我现在在找css的歪门邪道,用JS的工作量就不如改HTML了。
        36
    tension   2015-01-30 14:25:51 +08:00
    还是上演示吧。。。 不然看图说话太累了,不知道你想实现的是什么效果
        37
    jarlyyn   2015-01-30 14:39:13 +08:00
    再看了下你的问题。你确定这个和父类或者继承有关吗?我怎么觉得你是父类有了padding,所以内部元素没法超框?这样的话用个负margin值就可以了。
        38
    wincat   2015-01-30 14:45:46 +08:00
    @jarlyyn 不只是父类padding的问题吧,bs的container类width在不同浏览器宽度范围下是一个相对固定的值。要让包含在container里的div宽度永远等于浏览器宽度,我认为使用固定的负值margin是无法保证刚好相等的。
        39
    jarlyyn   2015-01-30 14:50:42 +08:00
    @wincat 你到底是要等于父类的宽,还是要等于屏幕的宽?这还是和继承没关系啊。是区域的结构或者划分的结构吧?
    如果只是自适应的话,去做相应宽度下的样式就好了么。
        40
    wincat   2015-01-30 14:57:17 +08:00
    @jarlyyn 我是要等于屏幕的宽,而不是父类的宽。
        41
    jankan   2015-01-30 15:10:57 +08:00
    #page-content {position:static}
    #headcontent {position:absolute;width:100%;height:xxxpx;}
        42
    jarlyyn   2015-01-30 15:24:34 +08:00
    @wincat 改html的吧,或者用jquery把你的子类在ready事件时移到body最后
        43
    lincanbin   2015-01-30 15:27:13 +08:00
    用important覆盖样式,不要在html中插style属性,样式和HTML分离是良好习惯
        44
    Aixtuz   2015-01-30 16:23:09 +08:00
    “>”: 用他的爷爷级,把属性控制在父亲级,然后孙子级就不受影响了~
    eg:
    #name1 > div
    只有name1下的直属div 受该属性影像。 div里如果再有div是不继承的。
        45
    shanelau   2015-01-30 17:20:38 +08:00
    !important; 覆盖掉所有的样式
        46
    dallaslu   2015-01-30 22:22:52 +08:00
    /*
    如果 #page-content 内部布局简单,可以试试。
    */

    #page-content {
    width: 100%;
    }

    #page-content > * {
    margin-left: auto;
    margin-right: auto;
    padding-left: 15px;
    padding-right: 15px;
    }

    #head-content {
    width: 100%;
    }

    @media (min-width: 768px) {
    #page-content > * { width: 750px; }
    }

    @media (min-width: 992px) {
    #page-content > * { width: 970px; }
    }

    @media (min-width: 1200px) {
    #page-content > * { width: 1170px; }
    }
        47
    dallaslu   2015-01-30 22:24:05 +08:00
    不好意思,@media 同学,@ 了你这么多遍!
        48
    dallaslu   2015-01-30 22:39:18 +08:00
    @juicy 我觉得这并不属于继承的问题,盒模型的属性并不像字体风格一样来自父级,只能说是「适应」父级。
        49
    strivek   2015-01-30 22:55:23 +08:00
    这是我简单写的demo
    http://codepen.io/nailu0/pen/gbxqoy/
    子元素想超过父元素宽度,最简单的方法是利用负margin值来实现
    设定一个很大的margin:0 -100%;内部可以继续用container居中,col,row来布局,也可以自己灵活处理。
        50
    Agromania   2015-01-30 23:04:33 +08:00
    楼主你的问题并不是继承了样式的问题,而是100%的base的问题。这个要么去掉上层所有的position:relative(可能破坏bs的布局),要么更改你的html结构,要么用js处理
        51
    0x142857   2015-01-30 23:11:25 +08:00 via Android
    @loading 用 id 写 css 是不推荐的做法
        52
    baconrad   2015-01-30 23:20:55 +08:00
    可以利用 calc & vw

    demo: http://codepen.io/anon/pen/PwKLwq
        53
    loading   2015-01-31 05:20:51 +08:00
    @0x142857 这个我知道的,感谢提醒。 ;-p
        54
    MaqicXu   2015-01-31 10:44:25 +08:00
    既然这样,你就不要用container装了嘛
        55
    jarlyyn   2015-01-31 10:49:55 +08:00 via Android
    @0x142857 为什么不推荐呢?如果的确不是类的语意,也不用id?
        56
    Biwood   2015-01-31 11:00:55 +08:00
    这个问题怎么还在讨论,晕,根据楼主描述,这根本不是CSS继承问题,也不是CSS优先级问题,很多人都搞错方向了,楼主说的明显是HTML结构问题。

    目前我想到两个办法来解决:
    第一个办法我在二楼已经说了,就是让这个div脱离文档流,就是用position:absolute或者position:fixed给div定位,这样div就可以相对于document来设置宽度了。

    第二个办法就是改变页面的HTML结构,你的要求是.container里面的div大于.container 本身,明显你这个结构写的不好,一般都是面积大的元素包含面积小的元素,你可以考虑改一下结构,比如让div在.container外面。
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   2419 人在线   最高记录 5043   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.3 · 28ms · UTC 13:51 · PVG 21:51 · LAX 05:51 · JFK 08:51
    ♥ Do have faith in what you're doing.