我正在尝试使用CSS创建墙面图案。墙应该从底部向上生长,就像现实生活中的墙一样。由于flex,我已经做了很多。我现在正试图以非均匀模式排列div,以使其更加逼真。 Like this(我知道有这方面的JavaScript解决方案,但无论如何我只能使用CSS来实现这一点吗?
body {
display: flex;
min-height: 100%;
background: #f8f8f8;
}
html {
min-height: 100%;
}
.flex-container {
padding: 0;
width: 100%;
height: auto;
margin: 0;
list-style: none;
display: flex;
align-items: flex-start;
/*display: grid;
grid-gap:1rem;
grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));*/
}
.wrap-reverse {
-webkit-flex-wrap: wrap-reverse;
flex-wrap: wrap-reverse;
}
.flex-item {
background: blue;
padding: 5px;
width: 100px;
height: 30px;
margin: 10px;
line-height: 30px;
color: white;
font-weight: bold;
font-size: 1em;
text-align: center;
}
<ul class="flex-container wrap-reverse">
<li class="flex-item">1</li>
<li class="flex-item">2</li>
<li class="flex-item">3</li>
<li class="flex-item">4</li>
<li class="flex-item">5</li>
<li class="flex-item">6</li>
<li class="flex-item">7</li>
<li class="flex-item">8</li>
<li class="flex-item">9</li>
<li class="flex-item">10</li>
<li class="flex-item">11</li>
<li class="flex-item">12</li>
<li class="flex-item">13</li>
<li class="flex-item">14</li>
<li class="flex-item">15</li>
<li class="flex-item">16</li>
<li class="flex-item">17</li>
<li class="flex-item">18</li>
<li class="flex-item">19</li>
<li class="flex-item">20</li>
<li class="flex-item">21</li>
<li class="flex-item">22</li>
<li class="flex-item">23</li>
<li class="flex-item">24</li>
<li class="flex-item">25</li>
<li class="flex-item">26</li>
<li class="flex-item">27</li>
<li class="flex-item">28</li>
<li class="flex-item">29</li>
<li class="flex-item">30</li>
<li class="flex-item">31</li>
<li class="flex-item">32</li>
<li class="flex-item">33</li>
<li class="flex-item">34</li>
<li class="flex-item">35</li>
<li class="flex-item">36</li>
<li class="flex-item">37</li>
<li class="flex-item">38</li>
<li class="flex-item">39</li>
<li class="flex-item">40</li>
<li class="flex-item">41</li>
<li class="flex-item">42</li>
<li class="flex-item">43</li>
<li class="flex-item">44</li>
<li class="flex-item">45</li>
<li class="flex-item">46</li>
<li class="flex-item">47</li>
<li class="flex-item">48</li>
<li class="flex-item">49</li>
<li class="flex-item">50</li>
<li class="flex-item">51</li>
<li class="flex-item">52</li>
<li class="flex-item">53</li>
<li class="flex-item">54</li>
<li class="flex-item">55</li>
<li class="flex-item">56</li>
<li class="flex-item">57</li>
<li class="flex-item">58</li>
<li class="flex-item">59</li>
<li class="flex-item">60</li>
<li class="flex-item">61</li>
<li class="flex-item">62</li>
<li class="flex-item">63</li>
<li class="flex-item">64</li>
<li class="flex-item">65</li>
<li class="flex-item">66</li>
<li class="flex-item">67</li>
<li class="flex-item">68</li>
<li class="flex-item">69</li>
<li class="flex-item">70</li>
<li class="flex-item">71</li>
<li class="flex-item">72</li>
<li class="flex-item">73</li>
<li class="flex-item">74</li>
<li class="flex-item">75</li>
<li class="flex-item">76</li>
<li class="flex-item">77</li>
<li class="flex-item">78</li>
<li class="flex-item">79</li>
<li class="flex-item">80</li>
<li class="flex-item">81</li>
<li class="flex-item">82</li>
<li class="flex-item">83</li>
<li class="flex-item">84</li>
<li class="flex-item">85</li>
<li class="flex-item">86</li>
<li class="flex-item">87</li>
<li class="flex-item">88</li>
<li class="flex-item">89</li>
<li class="flex-item">90</li>
<li class="flex-item">91</li>
<li class="flex-item">92</li>
<li class="flex-item">93</li>
<li class="flex-item">94</li>
<li class="flex-item">95</li>
<li class="flex-item">96</li>
<li class="flex-item">97</li>
<li class="flex-item">88</li>
<li class="flex-item">99</li>
<li class="flex-item">100</li>
</ul>
答案 0 :(得分:3)
您也可以使用background: linear-gradient
制作它。用更少的代码。
希望这会有所帮助:)
div {
width:100%;
height:100vh;
display:inline-block;
background: linear-gradient(163deg, transparent 0px, transparent 1px, #222 1px, #222 14px, transparent 14px), linear-gradient(161deg, transparent 0px, #181818 1px, #222 2px, #222 15px, transparent 15px), linear-gradient(343deg, transparent 0px, transparent 1px, #222 1px, #222 14px, transparent 14px), linear-gradient(343deg, transparent 0px, transparent 1px, #222 1px, #222 14px, transparent 14px);
background-color: #585858;
background-position: 2px 1px, 23px 16px,48px 15px, 21px 30px;
background-size: 48px 30px;
}
<div></div>
答案 1 :(得分:2)
我为你做了一个逻辑。
假设您在第一行中有4个项目,这意味着您将在第二行中拥有5个项目。因此,两行中的总项数为 4 + 5 = 9
所以你必须针对这些项目:nth-child(9n)和 n-child(9n + 5)
注意:(9n)也可以写成(9n + 0)或(9n + 9)
只需将这些项目的宽度更改为其他项目的一半即可。
Stack Snippet
body {
display: flex;
min-height: 100%;
background: #ffffff;
}
html {
min-height: 100%;
}
.flex-container {
padding: 0;
width: 100%;
height: auto;
margin: 0;
list-style: none;
display: flex;
align-items: flex-start;
flex-wrap: wrap;
}
.wrap-reverse {
-webkit-flex-wrap: wrap-reverse;
flex-wrap: wrap-reverse;
}
.flex-item {
background: blue;
padding: 5px;
width: 25%;
height: 50px;
border: 5px solid #fff;
line-height: 30px;
color: white;
font-weight: bold;
font-size: 1em;
text-align: center;
box-sizing: border-box;
}
.flex-item:nth-child(9n),
.flex-item:nth-child(9n+5) {
width: 12.5%;
}
<ul class="flex-container wrap-reverse">
<li class="flex-item">1</li>
<li class="flex-item">2</li>
<li class="flex-item">3</li>
<li class="flex-item">4</li>
<li class="flex-item">5</li>
<li class="flex-item">6</li>
<li class="flex-item">7</li>
<li class="flex-item">8</li>
<li class="flex-item">9</li>
<li class="flex-item">10</li>
<li class="flex-item">11</li>
<li class="flex-item">12</li>
<li class="flex-item">13</li>
<li class="flex-item">14</li>
<li class="flex-item">15</li>
<li class="flex-item">16</li>
<li class="flex-item">17</li>
<li class="flex-item">18</li>
<li class="flex-item">19</li>
<li class="flex-item">20</li>
<li class="flex-item">21</li>
<li class="flex-item">22</li>
<li class="flex-item">23</li>
<li class="flex-item">24</li>
<li class="flex-item">25</li>
<li class="flex-item">26</li>
<li class="flex-item">27</li>
<li class="flex-item">28</li>
<li class="flex-item">29</li>
<li class="flex-item">30</li>
<li class="flex-item">31</li>
<li class="flex-item">32</li>
<li class="flex-item">33</li>
<li class="flex-item">34</li>
<li class="flex-item">35</li>
<li class="flex-item">36</li>
<li class="flex-item">37</li>
<li class="flex-item">38</li>
<li class="flex-item">39</li>
<li class="flex-item">40</li>
<li class="flex-item">41</li>
<li class="flex-item">42</li>
<li class="flex-item">43</li>
<li class="flex-item">44</li>
<li class="flex-item">45</li>
<li class="flex-item">46</li>
<li class="flex-item">47</li>
<li class="flex-item">48</li>
<li class="flex-item">49</li>
<li class="flex-item">50</li>
<li class="flex-item">51</li>
<li class="flex-item">52</li>
<li class="flex-item">53</li>
<li class="flex-item">54</li>
<li class="flex-item">55</li>
<li class="flex-item">56</li>
<li class="flex-item">57</li>
<li class="flex-item">58</li>
<li class="flex-item">59</li>
<li class="flex-item">60</li>
<li class="flex-item">61</li>
<li class="flex-item">62</li>
<li class="flex-item">63</li>
<li class="flex-item">64</li>
<li class="flex-item">65</li>
<li class="flex-item">66</li>
<li class="flex-item">67</li>
<li class="flex-item">68</li>
<li class="flex-item">69</li>
<li class="flex-item">70</li>
<li class="flex-item">71</li>
<li class="flex-item">72</li>
<li class="flex-item">73</li>
<li class="flex-item">74</li>
<li class="flex-item">75</li>
<li class="flex-item">76</li>
<li class="flex-item">77</li>
<li class="flex-item">78</li>
<li class="flex-item">79</li>
<li class="flex-item">80</li>
<li class="flex-item">81</li>
<li class="flex-item">82</li>
<li class="flex-item">83</li>
<li class="flex-item">84</li>
<li class="flex-item">85</li>
<li class="flex-item">86</li>
<li class="flex-item">87</li>
<li class="flex-item">88</li>
<li class="flex-item">89</li>
<li class="flex-item">90</li>
<li class="flex-item">91</li>
<li class="flex-item">92</li>
<li class="flex-item">93</li>
<li class="flex-item">94</li>
<li class="flex-item">95</li>
<li class="flex-item">96</li>
<li class="flex-item">97</li>
<li class="flex-item">88</li>
<li class="flex-item">99</li>
</ul>
要进一步优化,您实际上不需要为每个项目class
。
如果li
中只有号码,请使用CSS counter。
body {
display: flex;
min-height: 100%;
background: #ffffff;
}
html {
min-height: 100%;
}
.flex-container {
padding: 0;
width: 100%;
height: auto;
margin: 0;
list-style: none;
display: flex;
align-items: flex-start;
flex-wrap: wrap;
}
.wrap-reverse {
-webkit-flex-wrap: wrap-reverse;
flex-wrap: wrap-reverse;
}
.flex-container li {
background: blue;
padding: 5px;
width: 25%;
height: 50px;
border: 5px solid #fff;
line-height: 30px;
color: white;
font-weight: bold;
font-size: 1em;
text-align: center;
box-sizing: border-box;
}
.flex-container li:nth-child(9n),
.flex-container li:nth-child(9n+5) {
width: 12.5%;
}
.flex-container {
counter-reset: my-counter;
}
.flex-container li:before {
counter-increment: my-counter;
content: counter(my-counter);
}
<ul class="flex-container wrap-reverse">
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
</ul>
答案 2 :(得分:0)
感谢所有帮助人员。这是我的最终结果:)
ul.wall {
list-style-type: none;
margin: 0;
padding:0;
}
li{
margin: 0;
}
.wall-bg{
background: #f8f8f8;
padding: 50px 0;
width: 100%;
}
.wall {
display: grid;
grid-template-columns: repeat(25, [col] 1fr);
grid-gap: 2px;
width: 100%;
-moz-transform: rotate(180deg);
-webkit-transform: rotate(180deg);
-ms-transform: rotate(180deg);
-o-transform: rotate(180deg);
transform: rotate(180deg);
direction: rtl;
}
.brick {
background-color: #98471f;
/*height: 25px*/
grid-column: span 2;
color: #c98a6a;
text-align:center;
padding: 6px 0;
transform: rotate(180deg);
direction: ltr;
}
@media (min-width: 1200px) {
.brick:nth-child(26n),
.brick:nth-child(26n+1) {
grid-column: span 1;
}
}
@media (min-width: 800px) and (max-width: 1200px) {
.wall {
grid-template-columns: repeat(17, [col] 1fr);
}
/*.brick {
height: 20px;
}*/
.brick:nth-child(16n),
.brick:nth-child(16n+1) {
grid-column: span 1;
}
}
@media (max-width: 800px) {
.wall {
grid-template-columns: repeat(11, [col] 1fr);
}
/*.brick {
height: 20px;
}*/
.brick:nth-child(12n),
.brick:nth-child(12n+1) {
grid-column: span 1;
}
}
&#13;
<div class="wall-bg">
<div class="container-fluid">
<ul class="wall">
<li class="brick">
001
</li>
<li class="brick">002</li>
<li class="brick">003</li>
<li class="brick">004</li>
<li class="brick">005</li>
<li class="brick">006</li>
<li class="brick">007</li>
<li class="brick">008</li>
<li class="brick">009</li>
<li class="brick">010</li>
<li class="brick">011</li>
<li class="brick">012</li>
<li class="brick">013</li>
<li class="brick">014</li>
<li class="brick">015</li>
<li class="brick">016</li>
<li class="brick">017</li>
<li class="brick">018</li>
<li class="brick">019</li>
<li class="brick">020</li>
<li class="brick">021</li>
<li class="brick">022</li>
<li class="brick">023</li>
<li class="brick">024</li>
<li class="brick">025</li>
<li class="brick">026</li>
<li class="brick">027</li>
<li class="brick">028</li>
<li class="brick">029</li>
<li class="brick">030</li>
<li class="brick">031</li>
<li class="brick">032</li>
<li class="brick">033</li>
<li class="brick">034</li>
<li class="brick">035</li>
<li class="brick">036</li>
<li class="brick">037</li>
<li class="brick">08</li>
<li class="brick">039</li>
<li class="brick">040</li>
<li class="brick">041</li>
<li class="brick">042</li>
<li class="brick">043</li>
<li class="brick">044</li>
<li class="brick">045</li>
<li class="brick">046</li>
<li class="brick">047</li>
<li class="brick">048</li>
<li class="brick">049</li>
<li class="brick">050</li>
<li class="brick">051</li>
<li class="brick">052</li>
<li class="brick">053</li>
<li class="brick">054</li>
<li class="brick">055</li>
<li class="brick">056</li>
<li class="brick">057</li>
<li class="brick">058</li>
<li class="brick">059</li>
<li class="brick">050</li>
<li class="brick">061</li>
<li class="brick">062</li>
<li class="brick">063</li>
<li class="brick">064</li>
<li class="brick">065</li>
<li class="brick">066</li>
<li class="brick">067</li>
<li class="brick">068</li>
<li class="brick">069</li>
<li class="brick">070</li>
<li class="brick">071</li>
<li class="brick">072</li>
<li class="brick">073</li>
<li class="brick">074</li>
<li class="brick">075</li>
<li class="brick">076</li>
<li class="brick">077</li>
<li class="brick">078</li>
<li class="brick">079</li>
<li class="brick">080</li>
<li class="brick">081</li>
<li class="brick">082</li>
<li class="brick">083</li>
<li class="brick">084</li>
<li class="brick">085</li>
<li class="brick">086</li>
<li class="brick">087</li>
<li class="brick">088</li>
<li class="brick">089</li>
<li class="brick">090</li>
<li class="brick">091</li>
<li class="brick">092</li>
<li class="brick">093</li>
<li class="brick">094</li>
<li class="brick">095</li>
<li class="brick">096</li>
<li class="brick">097</li>
<li class="brick">098</li>
<li class="brick">099</li>
<li class="brick">100</li>
<li class="brick">101</li>
<li class="brick">102</li>
<li class="brick">103</li>
<li class="brick">104</li>
<li class="brick">105</li>
<li class="brick">106</li>
<li class="brick">107</li>
<li class="brick">108</li>
<li class="brick">109</li>
<li class="brick">110</li>
<li class="brick">111</li>
<li class="brick">112</li>
<li class="brick">113</li>
<li class="brick">114</li>
<li class="brick">115</li>
<li class="brick">116</li>
<li class="brick">117</li>
<li class="brick">118</li>
<li class="brick">119</li>
<li class="brick">120</li>
<li class="brick">121</li>
<li class="brick">122</li>
<li class="brick">123</li>
<li class="brick">124</li>
<li class="brick">125</li>
<li class="brick">126</li>
<li class="brick">127</li>
<li class="brick">128</li>
<li class="brick">129</li>
<li class="brick">130</li>
<li class="brick">131</li>
<li class="brick">132</li>
<li class="brick">133</li>
<li class="brick">134</li>
<li class="brick">135</li>
<li class="brick">136</li>
<li class="brick">137</li>
<li class="brick">138</li>
<li class="brick">139</li>
<li class="brick">140</li>
<li class="brick">141</li>
<li class="brick">142</li>
<li class="brick">143</li>
<li class="brick">144</li>
<li class="brick">145</li>
<li class="brick">146</li>
<li class="brick">147</li>
<li class="brick">148</li>
<li class="brick">149</li>
<li class="brick">150</li>
</ul>
</div>
</div>
&#13;