前端 两个复选框当只少选中一个_前端开发者们值得了解的 11 项前端技巧

2bba0f0544fe9bef7968f39190f5c741.png
不容错过的 11 项 HTML/JS/CSS 技巧。

通过以下 HTML/CSS/JavaScript 相关技巧,希望能帮助大家填补一点点关于前端开发方面的知识空白。

1、Datalist 元素

这项 HTML 元素的使用频率极低,今天我们就要为它正名!

< datalist>标签用于为< input>元素提供一项“自动补全”功能。在键入过程中,您会看到如下图所示的预定义下拉菜单及选项。

5406612cda924ad79f3dd95349c67be5.png

示例:

<input**list="animals"**name="animal" id="animal"><datalist**id="animals"**>
<option value="Cat">
<option value="Dog">
<option value="Chicken">
<option value="Cow">
<option value="Pig">
</datalist>

<datalist>列出的属性(参见上方粗体)必须等于<input>的 id,因为需要将二者捆绑使用。

2. 带有复选框的可点击标签

如果大家希望使用带有复选框的可点击标签,最常见的作法可能是将 label 元素与“for”属性结合使用,详见以下代码。

<input type="checkbox" name="checkbox" id="checkbox_id" value="value">
<label for="checkbox_id">I agree</label>

实际上,您完全可以将 label 元素直接放在复选框旁边以达成相同的效果。这样,我们就能点击“I agree”并轻松选中该复选框!

示例:

<label><input type="checkbox" name="checkbox" id="checkbox_id" value="value"></label>

3. 子选择器

这可能是本份清单中知名度最高的技巧了,但大多数朋友并没有意识到它的强大力量。

子选择器用于匹配某一指定元素的全部子元素。它能够给出两项元素之间的关系。

示例:

/* 1st <li> element */
li:first-child{
    color: red;
}

/* Last <li> element */
li:last-child{
    color: green;
}

// Select All <li> elements but The First Three */
li:nth-child(n+4) {
    color: yellow;
}

/* Select only the first 3 <li>elemets*/
li:nth-child(-n+3) {
    color: green;
}

/* Styles are elements that are not a <p> */
.my-class:not(p) {
    display: none;
}

4. 写作模式

写作模式是一项鲜为人知,但却极为强大的 CSS 属性。

您可以借此让文本以垂直形式排列:

6f84e83492ef2ae059057df1ca8c2518.png

完成此操作的代码非常简单。

writing-mode: vertical-rl;

完整示例:

<style>
.sideway {
    writing-mode: vertical-rl;
}
.normal {
    width: 5%;
    float: left;
}
</style>
<p class="normal">
    Hi some paragraph text
</p>
<p class="sideway">
    Hey I'm somesidwaytext
</p>

其中 writing-mode 属性还包含五个具体选项。

writing-mode: horizontal-tb;
writing-mode: vertical-rl;
writing-mode: vertical-lr;
writing-mode: sideways-rl;
writing-mode: sideways-lr;

5.calc() 函数

calc()CSS 函数允许您在指定 CSS 属性值的前提下执行计算。

大家在 calc() 中用得最多的功能,应该就是混合单位了,例如将百分比与像素相混合。这项任务无法由预处理器完成,只能在渲染过程中执行。

示例:

width:calc(5px + 100px);
width:calc(6em * 8);
width:calc(100% - 50px);

6.Math.round 与 Math.floor 备选项

这项技巧虽然有点难度,但效果也相当出色。

Math.floor() 您可以使用 0|:

**0|**743.4343 // returns 743
Math.floor(743.4343) // returns 743

Math.round() 您可以使用 +.5|0:

812.777**+.5|0**// returns 813
Math.round(812.777) // returns 813

7.Console.table

不少朋友可能已经听说并使用过 console.log(),但对于 console.table() 恐怕还比较陌生。它的作用是接收一个数组或者一个对象,从而以非常整洁的方式在控制台视图内显示一份表格!

数组示例:

let car1 ={ name: "Audi", model : "A4" }
let car2 = { name : "Volvo", model : "XC90" }
let car3 = { name : "Ford", model : "Fusion" }console.table([car1, car2, car3]);

6459c2af3ba35a5ec742ab157183457c.png

8.Console.time

另一项非常实用的控制台方法。console.time() 会启动一个计时器,以参数作为标签,而后使用具有相同标签名称的 console.timeEnd(),使控制台以毫秒为单位输出以 console.time() 及 console.timeEnd() 调用为起点的时间。

562eaf1522b74a8aaded72505a8675f3.png

示例:

// Starts the timer
console.time("MyTimer");// Ends the timer and outputs the time in milliseconds
console.timeEnd("MyTimer");

9. In 操作符

“In”操作符能够检查数组中是否存在索引,并返回 true 或 false 结果。

示例:

let cars = ['Audi', 'BMW', 'Mini', 'Bentley', 'Porsche'];0 in cars // returns true
3 in cars // returns true
6 in cars // returns false

您也可以借此检查对象中是否存在某项属性。

示例:

constperson ={firstName: "Dave", surname: "Smith", age: 34 };'firstName' in person // returns true
'surname' in person // returns true
'age' in person // returns true
'gendar' in person // returns false

10. 将 Chrome 作为文本编辑器

这是一项偶然的发现:如果大家在 Chrome 浏览器的网址栏中输入以下内容,然后按下回车,浏览器就会变成记事本形式。

data:text/html,<htmlcontenteditable>

11. 在 if 代码块中,去掉多个语句之间的大括号

if (1 === 1)
alert("Alert 1"), alert("Alert 2");

总结

虽然这 11 项技巧未必都很实用,但至少也算是各具价值,而且大多没能在实际前端开发中得到重视。肯定还有更多重要技巧等待我们挖掘,期待听到大家的分享与推荐!

作者:Daniel Anderson
链接:前端开发者们值得了解的 11 项前端技巧
来源:微信公众号前端之巅
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
微信开发者工具是一款非常强大的工具,可以帮助开发者快速、高效地制作各种微信小程序。如果要用微信开发者工具制作一个购物app,首先需要构建一个完整的前端代码。在编写前端代码时,可以使用HTML、CSS和JavaScript等技术来实现页面布局、样式设计和交互功能。 在购物app的前端代码中,需要包含用户登录注册、商品浏览、购物车管理、订单支付等功能模块。其中用户登录注册模块可以使用微信小程序提供的登录授权功能,商品浏览模块可以展示商品列表和详情页面,购物车管理模块可以实现商品的添加、删除和数量编辑,订单支付模块可以调用微信支付接口完成支付操作。 在编写前端代码时,可以充分利用微信小程序提供的组件和API,如swiper、swiper-item、button、input等组件来实现页面的布局和功能。同时也要注意前端代码的性能优化和用户体验设计,确保app在不同的设备上都能正常运行并且具有良好的用户体验。 最后,完成了购物app的前端代码后,需要在微信开发者工具中创建一个新的小程序目,并将前端代码导入到目中进行调试和预览。在微信开发者工具中,可以通过模拟器和真机调试来检查程序的运行效果,并及时发现和修复bug。 总之,用微信开发者工具制作一个购物app的前端代码需充分利用HTML、CSS、JavaScript等技术,并结合微信小程序提供的组件和API来实现各种功能模块,最终达到一个用户友好的购物体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值