当前位置:网站首页>牛客刷题:数组排序
牛客刷题:数组排序
2022-08-02 21:27:00 【废物的自我修养记录】
题目描述
请补全JavaScript代码,根据预设代码中的数组,实现以下功能:
- 列表只展示数组中的name属性
- 实现点击"销量升序"按钮,列表内容按照销量升序重新渲染
- 实现点击"销量降序"按钮,列表内容按照销量降序重新渲染
注意: - 必须使用DOM0级标准事件(onclick)
实现:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
</head>
<body>
<button class='up'>销量升序</button>
<button class='down'>销量降序</button>
<ul></ul>
<script> var cups = [ {
type: 1, price: 100, color: 'black', sales: 3000, name: '牛客logo马克杯' }, {
type: 2, price: 40, color: 'blue', sales: 1000, name: '无盖星空杯' }, {
type: 4, price: 60, color: 'green', sales: 200, name: '老式茶杯' }, {
type: 3, price: 50, color: 'green', sales: 600, name: '欧式印花杯' } ] var ul = document.querySelector('ul'); var upbtn = document.querySelector('.up'); var downbtn = document.querySelector('.down'); // 补全代码 cups.forEach(ele=>{
const li=document.createElement('li') li.innerText=ele.name; ul.appendChild(li) }) upbtn.onclick=function(){
const lis=document.querySelectorAll('li') Array.from(lis).forEach(ele=>ul.removeChild(ele)) cups.sort((x,y)=>x.sales-y.sales) cups.forEach(ele=>{
const li=document.createElement('li') li.innerText=ele.name; ul.appendChild(li) }) } downbtn.onclick=function(){
const lis=document.querySelectorAll('li') Array.from(lis).forEach(ele=>ul.removeChild(ele)) cups.sort((x,y)=>y.sales-x.sales) cups.forEach(ele=>{
const li=document.createElement('li') li.innerText=ele.name; ul.appendChild(li) }) } </script>
</body>
</html>
边栏推荐
猜你喜欢
随机推荐
【干货】分库分表最佳实践
IP Protocol (Internet Protocol)
[C题目]力扣142. 环形链表 II
js function anti-shake and function throttling and other usage scenarios
YOLOv5+BiSeNet——同时进行目标检测和语义分割
[c] Detailed explanation of operators (1)
测试ESP32-Zigbee转发命令 : 滑轨、继电器控制
golang刷leetcode: 卖木头块
LeetCode 2359. 找到离给定两个节点最近的节点 基环树
VisualStudio 制作Dynamic Link Library动态链接库文件
回文自动机+CodeTON Round 2 C,D
【DEBUG】ImportError: Unable to import required dependencies: numpy: DLL load failed: 找不到指定的模块。
JumpServer开源堡垒机完成龙芯架构兼容性认证
增删改查这么多年,最后栽在MySQL的架构设计上!
Jar包启动通过ClassPathResource获取不到文件路径问题
Use the TCP protocol, we won't lost package?
Zabbix 5.0 Monitoring Tutorial (2)
如何抓住NFT、元|宇|宙新趋势?
FRED应用:激光二极管光源耦合到光纤的仿真
Ansible installation and configuration