前端问题合集
1.nginx跨域
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
| server { listen 90; server_name localhost;
location / { root html; index index.html index.htm; try_files $uri $uri/ /index.html; } #解决跨域问题,核心代码 location ^~ /api/ { rewrite ^/api/(.*)$ /$1 break; proxy_pass http://localhost:8080; } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } }
|
2.在vue3项目中控制element-ui左侧菜单的展开和收起
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67
| <template> <div :v-model='isCollapse'> <el-icon v-if="isCollapse" @click="change"><DArrowRight /></el-icon> <el-icon v-else @click="change"><DArrowLeft /></el-icon> </div> <el-menu default-active="2" class="el-menu-vertical-demo" :collapse="isCollapse" > <el-sub-menu index="1"> <template #title> <el-icon><Location /></el-icon> <span>Navigator One</span> </template> <el-menu-item-group> <template #title><span>Group One</span></template> <el-menu-item index="1-1">item one</el-menu-item> <el-menu-item index="1-2">item two</el-menu-item> </el-menu-item-group> <el-menu-item-group title="Group Two"> <el-menu-item index="1-3">item three</el-menu-item> </el-menu-item-group> <el-sub-menu index="1-4"> <template #title><span>item four</span></template> <el-menu-item index="1-4-1">item one</el-menu-item> </el-sub-menu> </el-sub-menu> <el-menu-item index="2"> <el-icon><icon-menu /></el-icon> <template #title>Navigator Two</template> </el-menu-item> <el-menu-item index="3" disabled> <el-icon><Document /></el-icon> <template #title>Navigator Three</template> </el-menu-item> <el-menu-item index="4"> <el-icon><setting /></el-icon> <template #title>Navigator Four</template> </el-menu-item> </el-menu> </template> <script setup> import { ref } from 'vue' import { DArrowLeft, DArrowRight, Document, Menu as IconMenu, Location, Setting, } from '@element-plus/icons-vue' const isCollapse = ref(false) const change=()=>{ isCollapse.value=!isCollapse.value } </script> <style> .el-menu-vertical-demo:not(.el-menu--collapse) { width: 200px; min-height: 400px; } </style>
|
3.在vue3中使用elementui中的cell-style控制表格中某行或者某单元格样式
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
| <el-table :cell-style="tableRowStyle" :data="tableData" table-layout:auto style="width: 100%;margin-top: 2vh" height="54vh" scrollbar-always-on border > <!-- 当type的值是index的时候表示序号 --> <el-table-column type="index" label="序号" prop="index" width="60"/> <el-table-column label="报修时间" prop="startDate" sortable/><!--sortable进行顺序排序 --> <el-table-column label="报修位置" prop="location"/> <el-table-column label="报修内容" prop="context"/> <el-table-column label="报修人 " prop="repairPerson"/> <el-table-column label="区域" prop="repairArea"/> <el-table-column label="受理状态" prop="flowerState"/> <el-table-column label="修复状态" prop="repairState"/> <el-table-column label="修复时间" prop="repairTime"/> <el-table-column label="修复人" prop="repairHandelPerson"/>
</el-table>
|
1 2 3 4 5 6 7
| const tableRowStyle = (data) => { if (data.row.repairState == "正在修复"&&data.column.property=="repairState") { return { color:'red' }; } }
|
4.让div盒子铺满全屏
在操作过程中我们发现,在全屏中使用div盒子的时候,在div盒子的左边和上面有一个8px的空隙,需要将其重置为0
1 2 3 4
| *{/* CSS Reset,解决存在的间距问题 */ margin : 0; padding : 0; }
|
5.渐变色
1 2
| /* 渐变色 */ background: linear-gradient(to bottom right, rgb(255, 2, 124), rgb(0, 255, 200)) no-repeat;
|
6.鼠标反应
1 2 3 4 5 6 7 8 9 10
| /* 聚焦时变化 */ .button:hover { background-color: rgba(123, 250, 252, 0.4); }
/* active点击后改变 */ /* :focus 元素被点击后变色,且颜色在点击后不消失 */ .button:active { background-color: rgba(193, 192, 192, 0.4); }
|
7.设置element-ui的某些样式
打开开发者模式,找到对应的class名称,进行设置
1 2 3 4 5 6
| .el-input .el-input__wrapper { margin: 0 auto; border-radius: 40px 40px 40px 40px; background-color: rgb(255, 255, 255, 0.4); }
|
8.密码框显示小眼睛
1 2 3 4
| <!-- show-password在密码旁边显示小眼睛 --> <el-form-item> <el-input placeholder="请输入密码" type="password" v-model="formLabelAlign.region" show-password /> </el-form-item>
|
9.设置圆角
1
| border-radius: 40px 40px 40px 40px;
|
10自动换行
1 2 3
| display: flex; flex-wrap: wrap; justify-content: start;
|
11.计算时间
1 2 3 4 5 6 7 8 9 10
| //sDate1和sDate2是2002-12-18格式 var now = new Date(); var sDate2 = "2024-04-18"; var nowData = now.getFullYear() + "-" + (now.getMonth() + 1) + "-" + now.getDate(); var aDate, oDate2, iDays aDate = nowData.split("-") nowData = new Date(aDate[1] + '-' + aDate[2] + '-' + aDate[0]) //转换为12-18-2002格式 aDate = sDate2.split("-") oDate2 = new Date(aDate[1] + '-' + aDate[2] + '-' + aDate[0]) iDays = parseInt(Math.abs(nowData - oDate2) / 1000 / 60 / 60 / 24) //把相差的毫秒数转换为天数
|
12.分隔线
1
| <hr class="hr-double-arrow">
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33
| .hr-double-arrow { color: #7171d5; border: double; border-width: 3px 5px; border-color: #5b336b transparent; height: 1px; overflow: visible; margin-left: 20px; margin-right: 20px; position: relative; }
.hr-double-arrow:before, .hr-double-arrow:after { content: ''; position: absolute; width: 5px; height: 5px; border-width: 0 3px 3px 0; border-style: double; top: -3px; background: radial-gradient(2px at 1px 1px, currentColor 2px, transparent 0) no-repeat; }
.hr-double-arrow:before { transform: rotate(-45deg); left: -20px; }
.hr-double-arrow:after { transform: rotate(135deg); right: -20px; }
|
13.md文件渲染
1
| npm i html-loader markdown-loader --save
|
14安装出现报错
1
| this[kHandle] = new _Hash(algorithm, xofLen);
|
出现原因:由于更新,导致node版本不匹配,要将该项目的启动选项进行修改
解决办法
1
| $env:NODE_OPTIONS="--openssl-legacy-provider"
|
15.路由缓存问题
缓存问题:当路由path一样,参数不同的时候会选择直接复用路由对应的组件
解决方案:
给 routerv-view 添加key属性,破坏缓存
使用 onBeforeRouteUpdate钩子函数,做精确更新
1 2 3 4 5 6 7 8 9
| import { onBeforeRouteUpdate } from 'vue-router'
// 目标:路由参数变化的时候 可以把分类数据接口重新发送 //to中为将要跳转时的最新路由 onBeforeRouteUpdate((to) => { // 存在问题:使用最新的路由参数请求最新的分类数据 //通过最新的路由去请求数据 getCategory(to.params.id) })
|
16.当切换路由时,在不同页面的滚动深度可能受到影响,需要在重新定义他的滚动高度
1 2 3 4 5 6 7 8 9 10 11
| //创建路由器 const router = createRouter({ history: createWebHistory(), routes: routes, //滚动条返回顶部 scrollBehavior () { return { top :0, } } });
|
17element-ui导航菜单高亮问题
在使用element-ui的meun时候,通过官方文档。我们可以知道可以给el-menu添加router属性,便可以在el-menu-item中设置index为路由地址,便可以实现点击跳转到指定路由
这样做可以实现路由跳转,但是刷新浏览器,会跳转默认路由。而不是我们离开时候的路由。
这时候我们就要将default-active设置为”$router.name”让其自动获取路由进行匹配,这时候我们需要将每个路由起一个名字
添加图片注释,不超过 140 字(可选)
将跳转路由的index名字与路由中的名字保持一致
添加图片注释,不超过 140 字(可选)
现在,我们刷新界面,会发现,虽然页面刷新了。但是路由没变,而且高亮还在
18.设置表头高亮
1
| :header-cell-style="{background:' #e7e1fb'
|