food-menu-home.html.html 28 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025
  1. <!DOCTYPE html>
  2. <html lang="zh-CN">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  6. <title>点菜喵点餐系统</title>
  7. <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css">
  8. <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/Swiper/8.4.5/swiper-bundle.min.css">
  9. <script src="https://cdnjs.cloudflare.com/ajax/libs/Swiper/8.4.5/swiper-bundle.min.js"></script>
  10. <style>
  11. * {
  12. margin: 0;
  13. padding: 0;
  14. box-sizing: border-box;
  15. font-family: 'PingFang SC', 'Microsoft YaHei', sans-serif;
  16. -webkit-tap-highlight-color: transparent;
  17. }
  18. :root {
  19. --primary: #ff6b6b;
  20. --primary-light: #ff8e8e;
  21. --primary-dark: #e55a5a;
  22. --secondary: #4ecdc4;
  23. --dark: #333;
  24. --gray: #666;
  25. --light-gray: #f5f5f5;
  26. --white: #fff;
  27. --card-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  28. --transition: all 0.3s ease;
  29. }
  30. body {
  31. background: linear-gradient(135deg, #fff5f5 0%, #fff0f0 100%);
  32. color: var(--dark);
  33. line-height: 1.6;
  34. padding-bottom: 80px;
  35. }
  36. .container {
  37. width: 100%;
  38. max-width: 480px;
  39. margin: 0 auto;
  40. padding: 0 15px;
  41. }
  42. /* Header Styles */
  43. header {
  44. background: var(--white);
  45. padding: 15px 0 10px;
  46. position: sticky;
  47. top: 0;
  48. z-index: 100;
  49. box-shadow: var(--card-shadow);
  50. }
  51. .header-container {
  52. display: flex;
  53. justify-content: space-between;
  54. align-items: center;
  55. padding: 0 15px;
  56. }
  57. .logo {
  58. display: flex;
  59. align-items: center;
  60. gap: 8px;
  61. font-size: 18px;
  62. font-weight: 700;
  63. color: var(--primary);
  64. }
  65. .logo i {
  66. font-size: 22px;
  67. }
  68. .user-actions {
  69. display: flex;
  70. gap: 15px;
  71. }
  72. .icon-btn {
  73. width: 36px;
  74. height: 36px;
  75. border-radius: 50%;
  76. display: flex;
  77. align-items: center;
  78. justify-content: center;
  79. background: var(--light-gray);
  80. color: var(--gray);
  81. font-size: 16px;
  82. border: none;
  83. }
  84. /* Search Bar */
  85. .search-bar {
  86. background: var(--light-gray);
  87. border-radius: 25px;
  88. padding: 10px 20px;
  89. margin: 12px 15px 0;
  90. display: flex;
  91. align-items: center;
  92. }
  93. .search-bar i {
  94. color: var(--gray);
  95. margin-right: 10px;
  96. }
  97. .search-bar input {
  98. border: none;
  99. background: transparent;
  100. outline: none;
  101. width: 100%;
  102. font-size: 14px;
  103. }
  104. /* Swiper Banner */
  105. .swiper-container {
  106. height: 160px;
  107. border-radius: 12px;
  108. margin: 15px;
  109. overflow: hidden;
  110. box-shadow: var(--card-shadow);
  111. }
  112. .swiper-slide {
  113. position: relative;
  114. overflow: hidden;
  115. display: flex;
  116. flex-direction: column;
  117. justify-content: center;
  118. padding: 0 25px;
  119. color: var(--white);
  120. }
  121. .slide-1 {
  122. background: linear-gradient(45deg, #ff9a9e, #fad0c4);
  123. }
  124. .slide-2 {
  125. background: linear-gradient(45deg, #a1c4fd, #c2e9fb);
  126. }
  127. .slide-3 {
  128. background: linear-gradient(45deg, #ffecd2, #fcb69f);
  129. }
  130. .swiper-slide h2 {
  131. font-size: 20px;
  132. margin-bottom: 8px;
  133. z-index: 2;
  134. text-shadow: 0 1px 2px rgba(0,0,0,0.2);
  135. }
  136. .swiper-slide p {
  137. font-size: 13px;
  138. opacity: 0.9;
  139. z-index: 2;
  140. text-shadow: 0 1px 2px rgba(0,0,0,0.2);
  141. }
  142. .swiper-pagination-bullet-active {
  143. background: var(--primary) !important;
  144. }
  145. /* Category Navigation */
  146. .category-nav {
  147. background: var(--white);
  148. border-radius: 12px;
  149. margin: 15px;
  150. padding: 15px 0;
  151. display: flex;
  152. justify-content: space-around;
  153. box-shadow: var(--card-shadow);
  154. }
  155. .category-item {
  156. display: flex;
  157. flex-direction: column;
  158. align-items: center;
  159. gap: 8px;
  160. cursor: pointer;
  161. transition: var(--transition);
  162. }
  163. .category-item:hover {
  164. transform: translateY(-5px);
  165. }
  166. .category-icon {
  167. width: 50px;
  168. height: 50px;
  169. background: rgba(255, 107, 107, 0.1);
  170. border-radius: 50%;
  171. display: flex;
  172. align-items: center;
  173. justify-content: center;
  174. color: var(--primary);
  175. font-size: 20px;
  176. }
  177. .category-text {
  178. font-size: 13px;
  179. color: var(--gray);
  180. }
  181. /* IP Entry */
  182. .ip-entry {
  183. position: fixed;
  184. right: 20px;
  185. bottom: 100px;
  186. z-index: 99;
  187. display: flex;
  188. flex-direction: column;
  189. align-items: center;
  190. }
  191. .ip-circle {
  192. width: 60px;
  193. height: 60px;
  194. border-radius: 50%;
  195. background: linear-gradient(135deg, var(--primary), var(--primary-light));
  196. display: flex;
  197. align-items: center;
  198. justify-content: center;
  199. box-shadow: 0 6px 15px rgba(255, 107, 107, 0.4);
  200. cursor: pointer;
  201. transition: var(--transition);
  202. }
  203. .ip-circle:hover {
  204. transform: scale(1.1);
  205. }
  206. .ip-circle img {
  207. width: 40px;
  208. height: 40px;
  209. }
  210. .ip-text {
  211. background: var(--white);
  212. color: var(--primary);
  213. font-size: 12px;
  214. font-weight: 600;
  215. padding: 4px 10px;
  216. border-radius: 20px;
  217. margin-top: 8px;
  218. box-shadow: 0 2px 8px rgba(0,0,0,0.1);
  219. }
  220. /* Shop Info Card */
  221. .shop-card {
  222. background: var(--white);
  223. border-radius: 15px;
  224. overflow: hidden;
  225. box-shadow: var(--card-shadow);
  226. margin: 15px;
  227. padding: 15px;
  228. }
  229. .shop-header {
  230. display: flex;
  231. align-items: center;
  232. gap: 15px;
  233. margin-bottom: 15px;
  234. }
  235. .shop-logo {
  236. width: 70px;
  237. height: 70px;
  238. border-radius: 10px;
  239. background: linear-gradient(45deg, #ff9a9e, #fad0c4);
  240. display: flex;
  241. align-items: center;
  242. justify-content: center;
  243. color: var(--white);
  244. font-size: 24px;
  245. font-weight: bold;
  246. flex-shrink: 0;
  247. }
  248. .shop-info {
  249. flex-grow: 1;
  250. }
  251. .shop-name {
  252. display: flex;
  253. align-items: center;
  254. gap: 8px;
  255. margin-bottom: 6px;
  256. }
  257. .shop-name h2 {
  258. font-size: 18px;
  259. }
  260. .rating {
  261. display: flex;
  262. align-items: center;
  263. gap: 5px;
  264. color: #ff922b;
  265. font-size: 14px;
  266. }
  267. .shop-tags {
  268. display: flex;
  269. flex-wrap: wrap;
  270. gap: 8px;
  271. margin: 10px 0;
  272. }
  273. .shop-tag {
  274. background: rgba(255, 107, 107, 0.1);
  275. color: var(--primary);
  276. padding: 4px 10px;
  277. border-radius: 20px;
  278. font-size: 12px;
  279. }
  280. .shop-stats {
  281. display: grid;
  282. grid-template-columns: repeat(3, 1fr);
  283. gap: 10px;
  284. margin-top: 15px;
  285. text-align: center;
  286. }
  287. .stat-item {
  288. padding: 10px;
  289. background: var(--light-gray);
  290. border-radius: 10px;
  291. }
  292. .stat-value {
  293. font-weight: bold;
  294. font-size: 16px;
  295. color: var(--primary);
  296. }
  297. .stat-label {
  298. font-size: 12px;
  299. color: var(--gray);
  300. margin-top: 4px;
  301. }
  302. /* Story Section */
  303. .story-section {
  304. background: var(--white);
  305. border-radius: 15px;
  306. overflow: hidden;
  307. box-shadow: var(--card-shadow);
  308. margin: 15px;
  309. padding: 15px;
  310. position: relative;
  311. }
  312. .story-header {
  313. display: flex;
  314. justify-content: space-between;
  315. align-items: center;
  316. margin-bottom: 15px;
  317. }
  318. .story-header h2 {
  319. font-size: 18px;
  320. color: var(--dark);
  321. position: relative;
  322. padding-left: 12px;
  323. }
  324. .story-header h2::before {
  325. content: '';
  326. position: absolute;
  327. left: 0;
  328. top: 50%;
  329. transform: translateY(-50%);
  330. width: 4px;
  331. height: 16px;
  332. background: var(--primary);
  333. border-radius: 2px;
  334. }
  335. .story-header .more {
  336. color: var(--gray);
  337. font-size: 13px;
  338. }
  339. .story-content {
  340. display: flex;
  341. gap: 15px;
  342. align-items: center;
  343. }
  344. .story-image {
  345. width: 100px;
  346. height: 100px;
  347. border-radius: 12px;
  348. background: linear-gradient(45deg, #ffecd2, #fcb69f);
  349. flex-shrink: 0;
  350. display: flex;
  351. align-items: center;
  352. justify-content: center;
  353. color: var(--primary);
  354. font-weight: bold;
  355. font-size: 14px;
  356. text-align: center;
  357. padding: 10px;
  358. overflow: hidden;
  359. }
  360. .story-details {
  361. flex: 1;
  362. }
  363. .story-title {
  364. font-size: 16px;
  365. font-weight: 600;
  366. margin-bottom: 8px;
  367. color: var(--primary);
  368. display: flex;
  369. align-items: center;
  370. gap: 8px;
  371. }
  372. .story-text {
  373. font-size: 13px;
  374. color: var(--gray);
  375. line-height: 1.6;
  376. margin-bottom: 10px;
  377. display: -webkit-box;
  378. -webkit-line-clamp: 3;
  379. -webkit-box-orient: vertical;
  380. overflow: hidden;
  381. }
  382. .story-meta {
  383. display: flex;
  384. justify-content: space-between;
  385. font-size: 12px;
  386. color: var(--gray);
  387. }
  388. .story-actions {
  389. display: flex;
  390. gap: 10px;
  391. margin-top: 15px;
  392. }
  393. .story-btn {
  394. flex: 1;
  395. padding: 8px 0;
  396. border-radius: 20px;
  397. text-align: center;
  398. font-size: 13px;
  399. cursor: pointer;
  400. transition: var(--transition);
  401. }
  402. .read-btn {
  403. background: var(--primary);
  404. color: var(--white);
  405. }
  406. .read-btn:hover {
  407. background: var(--primary-dark);
  408. }
  409. .share-btn {
  410. background: rgba(255, 107, 107, 0.1);
  411. color: var(--primary);
  412. }
  413. .share-btn:hover {
  414. background: rgba(255, 107, 107, 0.2);
  415. }
  416. /* Menu Section */
  417. .section {
  418. margin: 20px 0;
  419. }
  420. .section-title {
  421. display: flex;
  422. justify-content: space-between;
  423. align-items: center;
  424. margin: 0 15px 15px;
  425. }
  426. .section-title h2 {
  427. font-size: 18px;
  428. color: var(--dark);
  429. position: relative;
  430. padding-left: 12px;
  431. }
  432. .section-title h2::before {
  433. content: '';
  434. position: absolute;
  435. left: 0;
  436. top: 50%;
  437. transform: translateY(-50%);
  438. width: 4px;
  439. height: 16px;
  440. background: var(--primary);
  441. border-radius: 2px;
  442. }
  443. .section-title .more {
  444. color: var(--gray);
  445. font-size: 13px;
  446. }
  447. /* Menu Item */
  448. .menu-list {
  449. display: grid;
  450. gap: 15px;
  451. }
  452. .menu-item {
  453. background: var(--white);
  454. border-radius: 15px;
  455. overflow: hidden;
  456. box-shadow: var(--card-shadow);
  457. display: flex;
  458. transition: var(--transition);
  459. }
  460. .menu-item:hover {
  461. transform: translateY(-3px);
  462. box-shadow: 0 8px 20px rgba(0, 0, 0, 0.1);
  463. }
  464. .menu-img {
  465. width: 100px;
  466. height: 100px;
  467. background: linear-gradient(45deg, #ff9a9e, #fad0c4);
  468. flex-shrink: 0;
  469. position: relative;
  470. }
  471. .menu-badge {
  472. position: absolute;
  473. top: 10px;
  474. right: 10px;
  475. background: var(--primary);
  476. color: var(--white);
  477. padding: 3px 10px;
  478. border-radius: 20px;
  479. font-size: 12px;
  480. font-weight: 600;
  481. }
  482. .menu-info {
  483. padding: 12px;
  484. flex-grow: 1;
  485. }
  486. .menu-name {
  487. display: flex;
  488. justify-content: space-between;
  489. margin-bottom: 8px;
  490. }
  491. .menu-name h3 {
  492. font-size: 16px;
  493. }
  494. .menu-price {
  495. color: var(--primary);
  496. font-weight: 600;
  497. }
  498. .menu-desc {
  499. font-size: 13px;
  500. color: var(--gray);
  501. margin-bottom: 10px;
  502. line-height: 1.5;
  503. }
  504. .menu-stats {
  505. display: flex;
  506. justify-content: space-between;
  507. font-size: 12px;
  508. color: var(--gray);
  509. }
  510. .menu-actions {
  511. display: flex;
  512. justify-content: flex-end;
  513. margin-top: 10px;
  514. }
  515. .add-btn {
  516. width: 80px;
  517. height: 32px;
  518. background: var(--primary);
  519. color: var(--white);
  520. border: none;
  521. border-radius: 16px;
  522. font-size: 14px;
  523. display: flex;
  524. align-items: center;
  525. justify-content: center;
  526. gap: 5px;
  527. transition: var(--transition);
  528. }
  529. .add-btn:hover {
  530. background: var(--primary-dark);
  531. }
  532. /* Bottom Navigation */
  533. .bottom-nav {
  534. position: fixed;
  535. bottom: 0;
  536. left: 0;
  537. width: 100%;
  538. background: var(--white);
  539. display: flex;
  540. border-top: 1px solid #eee;
  541. z-index: 100;
  542. }
  543. .nav-item {
  544. flex: 1;
  545. text-align: center;
  546. padding: 12px 0;
  547. color: var(--gray);
  548. font-size: 12px;
  549. position: relative;
  550. }
  551. .nav-item.active {
  552. color: var(--primary);
  553. }
  554. .nav-item.active::after {
  555. content: '';
  556. position: absolute;
  557. top: 0;
  558. left: 50%;
  559. transform: translateX(-50%);
  560. width: 30px;
  561. height: 3px;
  562. background: var(--primary);
  563. border-radius: 3px;
  564. }
  565. .nav-item i {
  566. font-size: 20px;
  567. margin-bottom: 4px;
  568. }
  569. /* Animation */
  570. @keyframes float {
  571. 0% { transform: translateY(0); }
  572. 50% { transform: translateY(-10px); }
  573. 100% { transform: translateY(0); }
  574. }
  575. .ip-circle {
  576. animation: float 3s ease-in-out infinite;
  577. }
  578. /* Responsive */
  579. @media (max-width: 480px) {
  580. .swiper-container {
  581. height: 140px;
  582. }
  583. .category-icon {
  584. width: 42px;
  585. height: 42px;
  586. font-size: 18px;
  587. }
  588. .shop-logo {
  589. width: 60px;
  590. height: 60px;
  591. }
  592. }
  593. </style>
  594. </head>
  595. <body>
  596. <div class="container">
  597. <!-- Header -->
  598. <header>
  599. <div class="header-container">
  600. <div class="logo">
  601. <i class="fas fa-cat"></i>
  602. <span>点菜喵</span>
  603. </div>
  604. <div class="user-actions">
  605. <button class="icon-btn">
  606. <i class="fas fa-bell"></i>
  607. </button>
  608. <button class="icon-btn">
  609. <i class="fas fa-user"></i>
  610. </button>
  611. </div>
  612. </div>
  613. <div class="search-bar">
  614. <i class="fas fa-search"></i>
  615. <input type="text" placeholder="搜索菜品、商家、分类...">
  616. </div>
  617. </header>
  618. <!-- Banner Swiper -->
  619. <div class="swiper-container">
  620. <div class="swiper-wrapper">
  621. <div class="swiper-slide slide-1">
  622. <h2>新店开业全场8折</h2>
  623. <p>仅限今日,限时优惠</p>
  624. </div>
  625. <div class="swiper-slide slide-2">
  626. <h2>点菜喵会员专享福利</h2>
  627. <p>积分兑换免单券</p>
  628. </div>
  629. <div class="swiper-slide slide-3">
  630. <h2>周末限定套餐</h2>
  631. <p>双人套餐仅需¥168</p>
  632. </div>
  633. </div>
  634. <div class="swiper-pagination"></div>
  635. </div>
  636. <!-- Category Navigation -->
  637. <div class="category-nav">
  638. <div class="category-item">
  639. <div class="category-icon">
  640. <i class="fas fa-fire"></i>
  641. </div>
  642. <div class="category-text">热销</div>
  643. </div>
  644. <div class="category-item">
  645. <div class="category-icon">
  646. <i class="fas fa-percent"></i>
  647. </div>
  648. <div class="category-text">折扣</div>
  649. </div>
  650. <div class="category-item">
  651. <div class="category-icon">
  652. <i class="fas fa-box"></i>
  653. </div>
  654. <div class="category-text">套餐</div>
  655. </div>
  656. <div class="category-item">
  657. <div class="category-icon">
  658. <i class="fas fa-tag"></i>
  659. </div>
  660. <div class="category-text">优惠</div>
  661. </div>
  662. <div class="category-item">
  663. <div class="category-icon">
  664. <i class="fas fa-utensils"></i>
  665. </div>
  666. <div class="category-text">小吃</div>
  667. </div>
  668. </div>
  669. <!-- IP Entry -->
  670. <div class="ip-entry">
  671. <div class="ip-circle">
  672. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="#fff" width="40px" height="40px">
  673. <path d="M0 0h24v24H0z" fill="none"/>
  674. <path d="M12 12c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm0 2c-2.67 0-8 1.34-8 4v2h16v-2c0-2.66-5.33-4-8-4z"/>
  675. </svg>
  676. </div>
  677. <div class="ip-text">点菜喵</div>
  678. </div>
  679. <!-- Shop Info Card -->
  680. <div class="shop-card">
  681. <div class="shop-header">
  682. <div class="shop-logo">喵</div>
  683. <div class="shop-info">
  684. <div class="shop-name">
  685. <h2>点菜喵主题餐厅</h2>
  686. <div class="rating">
  687. <i class="fas fa-star"></i>
  688. <span>4.9</span>
  689. </div>
  690. </div>
  691. <div class="shop-tags">
  692. <span class="shop-tag">网红打卡</span>
  693. <span class="shop-tag">人气爆款</span>
  694. <span class="shop-tag">宠物友好</span>
  695. </div>
  696. </div>
  697. </div>
  698. <div class="shop-stats">
  699. <div class="stat-item">
  700. <div class="stat-value">¥3.5</div>
  701. <div class="stat-label">配送费</div>
  702. </div>
  703. <div class="stat-item">
  704. <div class="stat-value">30min</div>
  705. <div class="stat-label">配送时间</div>
  706. </div>
  707. <div class="stat-item">
  708. <div class="stat-value">营业中</div>
  709. <div class="stat-label">09:00-22:00</div>
  710. </div>
  711. </div>
  712. </div>
  713. <!-- Story Section -->
  714. <div class="story-section">
  715. <div class="story-header">
  716. <h2>菜品故事</h2>
  717. <a href="#" class="more">更多故事</a>
  718. </div>
  719. <div class="story-content">
  720. <div class="story-image">
  721. 酸菜鱼<br>传统工艺
  722. </div>
  723. <div class="story-details">
  724. <div class="story-title">
  725. <i class="fas fa-utensils"></i> 酸菜鱼的传奇故事
  726. </div>
  727. <div class="story-text">
  728. 酸菜鱼源于重庆江津,已有百年历史。传说清朝末年,一位渔夫将刚捕获的鱼与自家腌制的酸菜同煮,意外发现其美味。这道菜融合了川菜的麻辣与酸菜的酸爽,鱼肉鲜嫩,汤汁醇厚...
  729. </div>
  730. <div class="story-meta">
  731. <span>阅读 2,856</span>
  732. <span>点赞 1,203</span>
  733. </div>
  734. </div>
  735. </div>
  736. <div class="story-actions">
  737. <div class="story-btn read-btn">阅读完整故事</div>
  738. <div class="story-btn share-btn">分享故事</div>
  739. </div>
  740. </div>
  741. <!-- Menu Section -->
  742. <div class="section">
  743. <div class="section-title">
  744. <h2>热销菜品</h2>
  745. <a href="#" class="more">查看全部</a>
  746. </div>
  747. <div class="menu-list">
  748. <!-- Menu 1 -->
  749. <div class="menu-item">
  750. <div class="menu-img">
  751. <div class="menu-badge">热销TOP1</div>
  752. </div>
  753. <div class="menu-info">
  754. <div class="menu-name">
  755. <h3>招牌酸菜鱼</h3>
  756. <div class="menu-price">¥68</div>
  757. </div>
  758. <div class="menu-desc">新鲜黑鱼片搭配秘制酸菜,麻辣鲜香</div>
  759. <div class="menu-stats">
  760. <span>月售 1286份</span>
  761. <span>好评率 98%</span>
  762. </div>
  763. <div class="menu-actions">
  764. <button class="add-btn">
  765. <i class="fas fa-plus"></i> 加入
  766. </button>
  767. </div>
  768. </div>
  769. </div>
  770. <!-- Menu 2 -->
  771. <div class="menu-item">
  772. <div class="menu-img">
  773. <div class="menu-badge">限时8折</div>
  774. </div>
  775. <div class="menu-info">
  776. <div class="menu-name">
  777. <h3>香辣小龙虾</h3>
  778. <div class="menu-price">¥98 <span style="text-decoration:line-through;color:#999;font-size:12px;margin-left:5px">¥128</span></div>
  779. </div>
  780. <div class="menu-desc">精选大号小龙虾,麻辣鲜香,肉质饱满</div>
  781. <div class="menu-stats">
  782. <span>月售 856份</span>
  783. <span>好评率 97%</span>
  784. </div>
  785. <div class="menu-actions">
  786. <button class="add-btn">
  787. <i class="fas fa-plus"></i> 加入
  788. </button>
  789. </div>
  790. </div>
  791. </div>
  792. <!-- Menu 3 -->
  793. <div class="menu-item">
  794. <div class="menu-img">
  795. <div class="menu-badge">新品</div>
  796. </div>
  797. <div class="menu-info">
  798. <div class="menu-name">
  799. <h3>金汤肥牛锅</h3>
  800. <div class="menu-price">¥58</div>
  801. </div>
  802. <div class="menu-desc">精选肥牛搭配南瓜金汤,微辣鲜香</div>
  803. <div class="menu-stats">
  804. <span>月售 523份</span>
  805. <span>好评率 99%</span>
  806. </div>
  807. <div class="menu-actions">
  808. <button class="add-btn">
  809. <i class="fas fa-plus"></i> 加入
  810. </button>
  811. </div>
  812. </div>
  813. </div>
  814. <!-- Menu 4 -->
  815. <div class="menu-item">
  816. <div class="menu-img">
  817. <div class="menu-badge">双人套餐</div>
  818. </div>
  819. <div class="menu-info">
  820. <div class="menu-name">
  821. <h3>情侣双人餐</h3>
  822. <div class="menu-price">¥168</div>
  823. </div>
  824. <div class="menu-desc">酸菜鱼+小龙虾+2份甜品+2杯饮品</div>
  825. <div class="menu-stats">
  826. <span>月售 342份</span>
  827. <span>好评率 100%</span>
  828. </div>
  829. <div class="menu-actions">
  830. <button class="add-btn">
  831. <i class="fas fa-plus"></i> 加入
  832. </button>
  833. </div>
  834. </div>
  835. </div>
  836. </div>
  837. </div>
  838. </div>
  839. <!-- Bottom Navigation -->
  840. <div class="bottom-nav">
  841. <div class="nav-item active">
  842. <i class="fas fa-home"></i>
  843. <div>首页</div>
  844. </div>
  845. <div class="nav-item">
  846. <i class="fas fa-search"></i>
  847. <div>发现</div>
  848. </div>
  849. <div class="nav-item">
  850. <i class="fas fa-book-open"></i>
  851. <div>故事</div>
  852. </div>
  853. <div class="nav-item">
  854. <i class="fas fa-shopping-cart"></i>
  855. <div>购物车</div>
  856. </div>
  857. <div class="nav-item">
  858. <i class="fas fa-user"></i>
  859. <div>我的</div>
  860. </div>
  861. </div>
  862. <script>
  863. // 初始化轮播图
  864. const swiper = new Swiper('.swiper-container', {
  865. loop: true,
  866. autoplay: {
  867. delay: 3000,
  868. disableOnInteraction: false,
  869. },
  870. pagination: {
  871. el: '.swiper-pagination',
  872. clickable: true,
  873. },
  874. });
  875. // 菜单项交互
  876. document.querySelectorAll('.add-btn').forEach(button => {
  877. button.addEventListener('click', function(e) {
  878. e.stopPropagation();
  879. const originalText = this.innerHTML;
  880. this.innerHTML = '<i class="fas fa-check"></i> 已添加';
  881. this.style.background = '#666';
  882. setTimeout(() => {
  883. this.innerHTML = originalText;
  884. this.style.background = '';
  885. }, 1500);
  886. });
  887. });
  888. // IP入口点击事件
  889. document.querySelector('.ip-circle').addEventListener('click', function() {
  890. alert('点菜喵智能推荐已开启!将为您推荐最合适的菜品~');
  891. });
  892. // 分类导航点击效果
  893. document.querySelectorAll('.category-item').forEach(item => {
  894. item.addEventListener('click', function() {
  895. const icon = this.querySelector('.category-icon');
  896. icon.style.background = 'var(--primary)';
  897. icon.style.color = 'var(--white)';
  898. setTimeout(() => {
  899. icon.style.background = '';
  900. icon.style.color = '';
  901. }, 300);
  902. });
  903. });
  904. // 故事按钮交互
  905. document.querySelector('.read-btn').addEventListener('click', function() {
  906. alert('即将打开酸菜鱼的完整故事...');
  907. });
  908. document.querySelector('.share-btn').addEventListener('click', function() {
  909. alert('分享菜品故事给好友');
  910. });
  911. </script>
  912. </body>
  913. </html>