Heim >Web-Frontend >CSS-Tutorial >Die neueste Codefreigabe im CSS-Checkbox-Stil
In diesem Artikel wird hauptsächlich die Codefreigabe einiger CSS-Checkbox--Kontrollkästchen-Stile vorgestellt. Für die Gestaltung einiger einfacher Seiten--Steuerelemente können sich bedürftige Freunde darauf beziehen
Checkbox ist ein HTML-Element, das wahrscheinlich jede Website verwendet, aber die meisten Leute gestalten es nicht, sodass sie auf den meisten Websites gleich aussehen. Warum gestalten Sie das Kontrollkästchen auf Ihrer Website nicht anders oder lassen es gar nicht wie ein Kontrollkästchen aussehen?
In diesem Tutorial erstellen wir 5 verschiedene Auswahlfelder, die Sie auf Ihrer Website verwenden können.
Sehen Sie sich die Demo an, um den Kontrollkästchenstil zu sehen, den wir erstellen werden.
Demo-Adresse
Zuerst müssen Sie ein Stück CSS hinzufügen, um alle Kontrollkästchen auszublenden. Als nächstes werden wir das Erscheinungsbild ändern. Dazu müssen Sie Ihrer CSS-Datei einen Code hinzufügen.
/** * 隐藏默认的checkbox */ input[type=checkbox] { visibility: hidden; }
Nachdem wir alle Kontrollkästchen ausgeblendet haben, müssen wir ein Label-HTML-Element hinzufügen. Wir alle wissen, dass beim Klicken das for-Attribut -Label erscheint, das entsprechende Das Kontrollkästchen Kontrollkästchen wird aktiviert. Das bedeutet, dass wir unsere Checkbox über das Klickereignis des Labels verarbeiten können .
Stil 1
Zustand an verschiedenen Orten angezeigt. Wenn Sie auf die Schaltfläche des Schiebereglers (Beschriftung) klicken, wird das Kontrollkästchen aktiviert und der Schieberegler bewegt sich in die Position EIN.
Wir beginnen mit der Erstellung des HTML für den Kontrollkästchenbereich.<section> <!-- Checbox One --> <h3>Checkbox One</h3> <p class="checkboxOne"> <input type="checkbox" value="1" id="checkboxOneInput" name="" /> <label for="checkboxOneInput"></label> </p> </section>Aufgrund dieser Art von Kontrollkästchen reicht eine Beschriftung nicht aus, um die Aufgabe abzuschließen. Wir verwenden ein p-Element, um das Kontrollkästchen zu enthalten. Wir müssen sie verwenden, um den schwarzen Streifen und die abgerundeten Ecken zu erstellen.
/** * Create the slider bar */ .checkboxOne { width: 40px; height: 10px; background: #555; margin: 20px 80px; position: relative; border-radius: 3px; }Jetzt können wir die Beschriftung als Schieberegler auf dem Streifen verwenden. Wir möchten, dass sich der Knopfeffekt von einer Seite des Streifens zur anderen bewegt. Wir können der Beschriftung einen Übergang hinzufügen.
/** * Create the slider from the label */ .checkboxOne label { display: block; width: 16px; height: 16px; border-radius: 50%; -webkit-transition: all .5s ease; -moz-transition: all .5s ease; -o-transition: all .5s ease; -ms-transition: all .5s ease; transition: all .5s ease; cursor: pointer; position: absolute; top: -3px; left: -3px; background: #ccc; }Da sich der Schieberegler nun in der aktivierten (ausgeschalteten) Position befindet, möchten wir, dass beim Aktivieren des Kontrollkästchens eine Reaktion erfolgt, damit wir den Schieberegler an das andere Ende bewegen können. Wir müssen wissen, ob das Kontrollkästchen aktiviert ist, und wenn ja, das linke Attribut des Beschriftungselements ändern.
/** * Move the slider in the correct position if the checkbox is clicked */ .checkboxOne input[type=checkbox]:checked + label { left: 27px; }Dies ist das CSS, das Sie für Ihre erste Checkbox benötigen.
Stil 2
<section> <!-- Checbox Two --> <h3>Checkbox Two</h3> <p class="checkboxTwo"> <input type="checkbox" value="1" id="checkboxTwoInput" name="" /> <label for="checkboxTwoInput"></label> </p> </section>Dieses p wird um einen Streifen größer als der Stil. Die Beschriftung wird weiterhin als Schieberegler verwendet. Verwenden Sie das folgende CSS, um es zu definieren.
/** * Checkbox Two */ .checkboxTwo { width: 120px; height: 40px; background: #333; margin: 20px 60px; border-radius: 50px; position: relative; }In der Mitte dieses Stils befindet sich ein schwarzer Balken. Der Schieberegler gleitet nach links und rechts, aber das p-Element wurde bereits verwendet, daher müssen wir
:before verwenden Pseudoklasse erstellt ein neues Element.
/** * Create the line for the circle to move across */ .checkboxTwo:before { content: ''; position: absolute; top: 19px; left: 14px; height: 2px; width: 90px; background: #111; }Wie Stil 1, als nächstes schreiben wir einen CSS-Stil für die Beschriftung und verwenden ihn als Schieberegler.
/** * Create the circle to click */ .checkboxTwo label { display: block; width: 22px; height: 22px; border-radius: 50%; -webkit-transition: all .5s ease; -moz-transition: all .5s ease; -o-transition: all .5s ease; -ms-transition: all .5s ease; transition: all .5s ease; cursor: pointer; position: absolute; top: 9px; z-index: 1; left: 12px; background: #ddd; }Ich möchte einen ausgewählten Status ähnlich dem Stil 1 erreichen und bei Auswahl die linken und Hintergrundattribute des Etiketts ändern.
/** * Create the click event for the checkbox */ .checkboxTwo input[type=checkbox]:checked + label { left: 84px; background: #26ca28; }
样式三
这个复选框的样式比样式二更复杂一些,它和前面的例子一样会左右滑动,并且当改变选中和未选中的状态时,滑块滑动到另一侧并且在原位置显示对应的文本。
首先,我们写HTML代码,这和前面是相同的。
<section> <!-- Checbox Three --> <h3>Checkbox Three</h3> <p class="checkboxThree"> <input type="checkbox" value="1" id="checkboxThreeInput" name="" /> <label for="checkboxThreeInput"></label> </p> </section>
然后,我们用相同的方式把p作为滑块,下面的代码会创建一个黑色圆角的条带,我们可以把滑块和文本放到里面。
/** * Checkbox Three */ .checkboxThree { width: 120px; height: 40px; background: #333; margin: 20px 60px; border-radius: 50px; position: relative; }
当滑块处于未选中状态时,滑块会在左侧,并且右边显示”OFF”,当点击的时候,滑块移动到右侧,左侧显示”ON”。
但是元素数量不足以让我们实现这些功能,所以我们要用:before和:after两个伪类创建两个元素,分别放置”ON”和”OFF”。
/** * Create the text for the On position */ .checkboxThree:before { content: 'On'; position: absolute; top: 12px; left: 13px; height: 2px; color: #26ca28; font-size: 16px; } /** * Create the label for the off position */ .checkboxThree:after { content: 'Off'; position: absolute; top: 12px; left: 84px; height: 2px; color: #ddd; font-size: 16px; }
和前面一样,我们来添加滑块的样式,当被点击时它会移动到另一侧,并且改变颜色。
/** * Create the pill to click */ .checkboxThree label { display: block; width: 52px; height: 22px; border-radius: 50px; -webkit-transition: all .5s ease; -moz-transition: all .5s ease; -o-transition: all .5s ease; -ms-transition: all .5s ease; transition: all .5s ease; cursor: pointer; position: absolute; top: 9px; z-index: 1; left: 12px; background: #ddd; } /** * Create the checkbox event for the label */ .checkboxThree input[type=checkbox]:checked + label { left: 60px; background: #26ca28; }
样式四
在这个样式中,我们会创建两个圆形,当点击时改变里面的圆形的颜色表示选中与未选中的状态。
和前面一样的HTML代码。
<section> <!-- Checbox Four --> <h3>Checkbox Four</h3> <p class="checkboxFour"> <input type="checkbox" value="1" id="checkboxFourInput" name="" /> <label for="checkboxFourInput"></label> </p> </section>
接下来我们要为checkbox创建外面的圆形,使用CSS的border-radius属性,并且设置为100%就可以创建一个正圆形。
<section> <!-- Checbox Four --> <h3>Checkbox Four</h3> <p class="checkboxFour"> <input type="checkbox" value="1" id="checkboxFourInput" name="" /> <label for="checkboxFourInput"></label> </p> </section>
然后我们用label元素来创建一个小一点的圆形,它会根据checkbox状态来改变颜色。
/** * Create the checkbox button */ .checkboxFour label { display: block; width: 30px; height: 30px; border-radius: 100px; -webkit-transition: all .5s ease; -moz-transition: all .5s ease; -o-transition: all .5s ease; -ms-transition: all .5s ease; transition: all .5s ease; cursor: pointer; position: absolute; top: 5px; left: 5px; z-index: 1; background: #333; -webkit-box-shadow:inset 0px 1px 3px rgba(0,0,0,0.5); -moz-box-shadow:inset 0px 1px 3px rgba(0,0,0,0.5); box-shadow:inset 0px 1px 3px rgba(0,0,0,0.5); }
当复选框被选中的时候,我们要改变内圈的背景颜色来表示选中状态。
/** * Create the checked state */ .checkboxFour input[type=checkbox]:checked + label { background: #26ca28; }
样式五
这个复选框的样式有些不同,它看起来只是比浏览器默认的checkbox样式稍微好了些,但是不同的是我们可以根据自己的需要来定义它的样式了。
首先还是一样的HTML代码
<section> <!-- Checbox Five --> <h3>Checkbox Five</h3> <p class="checkboxFive"> <input type="checkbox" value="1" id="checkboxFiveInput" name="" /> <label for="checkboxFiveInput"></label> </p> </section>
在前面的例子中,我们把p作为checkbox的滑动条带或者外部的圆圈,但是这一次我们不需要了,可以使用p元素来设置复选框的区域。
/** * Checkbox Five */ .checkboxFive { width: 25px; margin: 20px 100px; position: relative; }
label标签用于Click事件和我们要定义的复选框的方框样式。
/** * Create the box for the checkbox */ .checkboxFive label { cursor: pointer; position: absolute; width: 25px; height: 25px; top: 0; left: 0; background: #eee; border:1px solid #ddd; }
接下来,我们要创建方框中的对勾,对于这一点,我们可以使用:after伪类创建一个新的元素,为了实现这个样式,我们可以创建一个5px x 9px的长方形并给他加上边框。这时候我们去掉上面和右边的边框之后,它会看起来像一个字母L。然后我们可以使用CSS的transform属性让它旋转一下,这样看起来就像是一个对勾。
/** * Display the tick inside the checkbox */ .checkboxFive label:after { opacity: 0.2; content: ''; position: absolute; width: 9px; height: 5px; background: transparent; top: 6px; left: 7px; border: 3px solid #333; border-top: none; border-right: none; -webkit-transform: rotate(-45deg); -moz-transform: rotate(-45deg); -o-transform: rotate(-45deg); -ms-transform: rotate(-45deg); transform: rotate(-45deg); }
在上面的CSS中,我们已经设置它的透明度为0.2,所以你会看到的复选框有一个半透明的对勾。你可以在悬停的时候加深一点,在选中时,可以把设置为不透明。
/** * Create the hover event of the tick */ .checkboxFive label:hover::after { opacity: 0.5; } /** * Create the checkbox state for the tick */ .checkboxFive input[type=checkbox]:checked + label:after { opacity: 1; }
Das obige ist der detaillierte Inhalt vonDie neueste Codefreigabe im CSS-Checkbox-Stil. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!