獨立完成一個移動端項目(不是很明白爲何會有這樣的商品管理後臺),還是有些經驗不足,包括對產品的全局思考,對插件的選擇等,都有考慮不周的缺點,導致自己中途想換圖形界面插件,浪費了點時間,這裏記錄下,總結下經驗,理一下思路。
1.對於項目的一些心得與體會
- 首先的一點,就是,對於圖形界面框架的選型,這個很重要,對於一項目來說,開始動手前就要對項目的設計圖有個完整的瞭解,以便於自己選擇插件或者框架;
- 然後就是,對於交互性操作,比如:上傳圖片,預覽圖片啥的,應該選擇是否是用圖形界面框架來實現還是另選專門的插件來實現
- 在完成項目中,我又新學到了上傳圖片插件vue-core-image-upload,移動端富文本編輯器vue-quill-editor
- 還有個地址的三級聯動mt-picker,(是基於mint-ui圖形界面框架的)
2.rem與px的轉換
- 從同事傳授中獲到的經驗,對於rem與px的轉換,就是在index.html模板文件中加入下面的腳本,然後就是1rem=100px(這個可能不準確,有更好的方法,各位大佬請在評論中留下,感激不盡)
<script type="text/javascript">
document.getElementsByTagName("html")[0].style.fontSize = 100 / 750 * window.screen.width + "px";
</script>
3.對於上傳圖片插件vue-core-image-upload中遇到的坑
- 對於跨域問題,有好多方法可以解決,這裏講的挺多的前端跨域解決方法
- 還有就是後臺設置響應頭access-control-allow-origin可以指定特定的域名,我這裏的後臺設置的就是access-control-allow-origin:*,就是因爲這樣,用這個上傳圖片的插件就會報錯
Access to XMLHttpRequest at 'https://....' from origin 'http://localhost:8080' has been blocked by CORS policy: The value of the 'Access-Control-Allow-Origin' header in the response must not be the wildcard '*' when the request's credentials mode is 'include'. The credentials mode of requests initiated by the XMLHttpRequest is controlled by the withCredentials attribute.
- 這個問題我蒙圈了好久,和後臺也講了,就是處於蒙圈狀態,已經允許跨域了,怎麼還報錯呢?很煩
然後,終於找了個方法解決(有用過其他的上傳插件,感覺不好用,代碼或者思路好亂)
- 其實這個插件中的文檔也有提示,只是剛用,還不是很會
<vue-core-image-upload
class="btn btn-primary"
:crop="false"
input-of-file="file"
@imageuploaded="loadMainImg"
:max-file-size="5242880"
:url="serverUrl"
:credentials="false" //允許攜帶cookie
></vue-core-image-upload>
對於附帶身份憑證的請求,服務器不得設置 Access-Control-Allow-Origin 的值爲“”。這是因爲請求的首部中攜帶了 Cookie 信息,如果 Access-Control-Allow-Origin 的值爲“”,請求將會失敗。
也就是說Access-Control-Allow-Credentials設置爲true的情況下
Access-Control-Allow-Origin不能設置爲*
4.基於mint-ui的三級地址選擇
<div class="modal" @click="handleCloseAddress">
<div class="cateContainer" @click.stop>
<div class="operateBtn">
<div class="cancelBtn" @click="handleCloseAddress">取消</div>
<div class="confirmBtn" @click="handleCloseAddress">確定</div>
</div>
<mt-picker class="addressPicker" :slots="myAddressSlots" @change="onAddressChange"></mt-picker>
</div>
</div>
// 定義一個包含中國省市區信息的json文件
import addressJson from '@/assets/common/address'
export default {
data() {
return {
myAddressSlots: [
{
flex: 1,
values: Object.keys(addressJson),
className: 'slot1',
textAlign: 'center'
}, {
divider: true,
content: '-',
className: 'slot2'
}, {
flex: 1,
values: ['市轄區'],
className: 'slot3',
textAlign: 'center'
},
{
divider: true,
content: '-',
className: 'slot4'
},
{
flex: 1,
values: ['東城區'],
className: 'slot5',
textAlign: 'center'
}
],
province:'省',
city:'市',
county:'區/縣',
}
},
methods: {
onAddressChange(picker, values) {
if(addressJson[values[0]]) {
picker.setSlotValues(1, Object.keys(addressJson[values[0]]));
picker.setSlotValues(2, addressJson[values[0]][values[1]]);
this.province = values[0];
this.city = values[1];
this.county = values[2];
}
},
}
}
5.關於對是否登錄的處理
- 開始也有做過登錄的管理後臺,不過,在進行登錄時,總會一閃過登錄的界面,這種感覺很不好,在這裏記錄下相比之前更好點的方法
- 在main.js文件中添加對router的鉤子函數
router.beforeEach((to, from, next) => {
let token = localStorage.getItem('token');
if (!token && to.path !== '/login') {
next('/login');
} else {
next();
}
});
- 通過判斷緩存裏是否有token來進行路由的跳轉
- 相對於之前的那種方法,這裏對路由的跳轉進行的攔截,在路由進行跳轉前,進行判斷
6.上拉加載mescroll.js插件
7.移動端富文本插件Vue-Quill-Editor
<template>
<quill-editor
v-model="richTextContent"
ref="myQuillEditor"
:options="editorOption"
@change="onEditorChange($event)">
</quill-editor>
</template>
<script>
import { quillEditor } from "vue-quill-editor";
import 'quill/dist/quill.core.css';
import 'quill/dist/quill.snow.css';
import 'quill/dist/quill.bubble.css';
export default{
data() {
return {}
},
methods: {
onEditorChange(e) {}
}
}
</script>
onEditorChange(e){
console.log(e)
this.richTextContent = e.html;
},
8.移動端圖片預覽插件
<img :src="url" v-preview="url" preview-nav-enable="false" />
需要在app.vue中加入如下代碼
<lg-preview></lg-preview>
9.總結
- 在以後的項目中,首先的一件事就是要對產品要有完成的瞭解,然後進行技術、框架的選型
- 對於插件,自己多嘗試才能知道是否符合你的要求
正在努力學習中,若對你的學習有幫助,留下你的印記唄(點個贊咯^_^)