当前位置: 首页 > news >正文

项目中的一些问题(补充)

描述问题

轮播****图循环异常
  • 你想要什么效果

  • 请求完接口数据后,数据渲染为轮播图,而且轮播图能循环播放

  • 哪个地方不是你预期的效果

  • 请求完接口数据后,轮播图也能正常轮播,但是播放到最后一幅后,不再循环播放

解决方案

<swiper>组件上添加 v-if=“swiperList.length”

分析原理

  • 如果没有加 v-if

  • 在接口数据到来之前,swiper已经初始化,此时数据为[], loop选项是针对空数据的循环控制,

而获取数据之后,虽然触发了视图更新,但只更新<swiper-slide>,而没有更新swiper配置,所以循环失效

  • 如果加了v-if

  • 在接口数据到来之前,因为swiper上有v-if的判断,此时数据为[],所以swiper组件根本没有初始化。而获取数据后,v-if判断为真,引时触发视图更新,就是针对所有图片的loop设置

vue3项目开发中注意事项

**配置css和js

  1. 安装重置样式normalize.css
npm i normalize.css
  1. 移动端适配js

    复制flexible.js到src/assets文件夹中

  2. 引入图标字体

    在assets/fonts中存入图标字体文件

    在assets/css中存入iconfont.css, 并修正路径

  3. 定义全局css

    在assets/css中创建global.css,定义全局样式

  4. 在main.js中引入以下文件 ,以便全局使用

// 引入重置样式 import 'normalize.css' import './assets/css/global.css' import './assets/css/iconfont.css' // 引入rem适配的js import './assets/flexible'
  1. 修改px-to-rem插件的配置

    基准font-size: 75

    规定屏幕宽度: 750

  2. App.vue的style标签中,去掉scoped属性

  3. 在任意组件中使用图标字体

<i class="iconfont icon-kefu"></i>

处理本地静态资源

<div class="logo"> <p><button>切换图片</button></p> <p><img :src="url" alt=""></p> <!-- <p><img src="../../../assets/img/m_hualogo.png" alt=""></p> --> </div>
<script> //引用本地静态资源模块 import logo from '../../../assets/img/m_hualogo.png' export default { data() { return { //引用本地静态资源,不能使用下面的方式 // url: '../../../assets/img/m_hualogo.png' url: logo, // 线上地址有效 // url: 'https://m.hua.com/content/vue/login/static/img/m_hualogo.png' } } } </script>

拼接

<script setup> let imgurl = 'baidu_logo.png'; var icon = new URL(`../assets/imgs/${imgurl}`, import.meta.url) change(){ // 2. 使用当前资源 // this.url = logo; this.url = new URL(`../../assets/images/m_home_logo.png`, import.meta.url); } </script> <template> <div class="imgs"> <img :src=icon alt=""> </div> </template>

vite 中使用 @ ,配置路径别名

修改vite.config.js

import { defineConfig } from "vite"; import vue from "@vitejs/plugin-vue"; import path from 'path' // https://vitejs.dev/config/ export default defineConfig({ plugins: [vue()], server: { //启动热更新 hmr: true, }, resolve: { // 配置路径别名 alias: { '@': path.resolve(__dirname, './src'), }, }, });
  1. Sass****的使用

  2. 全局引入****sass

  • src/assets/scss/common.scss
$$green: #0f0; ul,li { list-style: none; background-color: $$green; }
  • 在main.js中引入
import "@/assets/scss/common.scss"
  1. 在指定组件中引入****sass
  • src/assets/scss/variables.scss (定义全量)
$bg: rgb(17, 24, 152);
  • 在组件中引入
<style lang="scss"> @import "./assets/scss/variables.scss"; $light: #f00; .app { width: 5rem; border: 1px solid $ light; background-color: $bg; } </style>
http://www.cnnetsun.cn/news/136519.html

相关文章:

  • 12.17 vue递归组件
  • QtScrcpy高刷投屏优化指南:告别卡顿,享受流畅体验
  • 终极移动端Windows应用运行指南:从零到流畅体验
  • 大学里的网络安全专业为什么没多少人就读?
  • 信息安全和网络空间安全这2个专业怎么选?老网安告诉你答案!
  • 英语发音MP3音频库:119,376个单词标准发音完整解决方案
  • 瞄准2026:AI安全、数据隐私与云原生——网络安全趋势预测与挑战分析
  • 重磅收藏!Java程序员转AI大模型:从代码高手到AI架构师的进阶指南
  • 2026网络安全进阶路线:盘点撬动高薪的四大关键证书
  • LangGraph实战教程:构建智能旅游规划助手,深入理解AI工作流架构【值得收藏】
  • 淘宝直播弹幕采集完整指南:5分钟快速上手数据分析
  • 文本驱动可视化:5分钟掌握专业级图表制作
  • Clipper2多边形处理技术深度解析与实战应用
  • 错过再等十年:AI驱动的生物制药Agent智能实验设计新范式
  • 造纸车间的“信号指挥官”:耐达讯自动化Profinet六路集线器,让变频器“步调一致”
  • MaterialDesignInXamlToolkit实战指南:5步打造现代化WPF界面
  • 中东电商市场,正在成为中国卖家的必争之地!
  • 为什么你的边缘Agent总是部署失败?深度剖析常见陷阱与对策
  • 一文搞定前端CSS常用布局
  • Kotaemon用户行为分析插件开发教程
  • 额温枪PCBA方案开发全流程规划
  • Kotaemon针灸穴位查询:图文结合精准定位
  • 二极管钳位三电平VSG仿真模型 1.加入中点电位平衡 2.仿真有视频教程 3.THD均<5%
  • 通达信轻松买卖点副图,源码分享
  • 仅限内部分享:电力巡检Agent路径生成模型参数调优全记录
  • ChromePass密码找回工具:轻松获取Chrome保存的所有密码
  • BookmarkHub:告别浏览器书签混乱的智能同步神器
  • 51、保障系统安全:从漏洞扫描到灾难恢复的全面指南
  • DearPyGUI:为什么这款Python GUI框架正在重新定义界面开发?
  • Matlab模拟OAM螺旋谱展开,包括光束本征态、各类湍流、衍射、干涉下的OAM谱分布