亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

使用vue完成微信公眾號網(wǎng)頁小記(推薦)

 更新時間:2019年04月28日 16:32:12   作者:小羊褲腳  
公司最近有一個H5頁面的功能,比較簡單的一個調(diào)查表功能,嵌套在我們微信公眾號里面。這篇文章主要介紹了使用vue完成微信公眾號網(wǎng)頁小記,需要的朋友可以參考下

前言:

公司最近有一個H5頁面的功能,比較簡單的一個調(diào)查表功能,嵌套在我們微信公眾號里面。選用的技術(shù)棧是Vue。同時用到了微信的登錄和分享接口。ps:本人小白,如果有問題希望大家能指出來,寫文章不止是為了記錄,還是為了發(fā)現(xiàn)自己的問題。謝謝大噶?。?!

主要功能以及遇到的問題:

  1. 左右切換動畫
  2. 路由帶參數(shù)跳轉(zhuǎn)
  3. 移動端引入外部字體樣式
  4. 使用htmtl2canvas截圖功能
  5. 使用微信接口(前端部分)
  6. 移動端屏幕適配
  7. 移動端點擊一個頁面點擊多次只執(zhí)行一次問題
  8. ios使用輸入框的時鍵盤彈起來掩蓋住按鈕問題
  9. 打包項目遇到靜態(tài)資源加載問題

1.左右切換動畫

--首先我考慮到用vue的移動端動畫庫,看了好久,但是項目非常小,就放棄了這個選擇自己開始手寫。首先我考慮到的是過渡效果。并且找到了相關(guān)的文章參考。代碼如下:

`<template>
 <div id="app">
 <transition :name="'fade-'+(direction==='forward'?'last':'next')">
 <router-view></router-view>
 </transition>
 </div>
</template>
<script>
export default {
 name: "app",
 data: () => {
 return {
 direction: ""
 };
 },
 watch: {
 $route(to, from) {
 let toName = to.name;
 const toIndex = to.meta.index;
 const fromIndex = from.meta.index;
 this.direction = toIndex < fromIndex ? "forward" : "";
 }
 }
}
</script>
<style scoped>
.fade-last-enter-active {
 animation: bounce-in 0.6s;
}
.fade-next-enter-active {
 animation: bounce-out 0.6s;
}
@keyframes bounce-in {
 0% {
 transform: translateX(-100%);
 }
 100% {
 transform: translateX(0rem);
 }
}
@keyframes bounce-out {
 0% {
 transform: translateX(100%);
 }
 100% {
 transform: translateX(0rem);
 }
}
</style>

2.路由帶參數(shù)跳轉(zhuǎn)

這個就是記錄一下,有三種方法。

1.直接在route-link:to 中帶參數(shù):

<router-link :to="{name:'home', query: {id:1}}">

2.在this.$router.push中帶參數(shù):

使用query帶參數(shù): 類似于get傳參 參數(shù)會拼接到url上面

this.$router.push({name:'home',query: {id:'1'}})
this.$router.push({path:'/home',query: {id:'1'}})

使用params帶參數(shù): 只能用name 類似于post 參數(shù)不會拼接

this.$router.push({name:'home',params: {id:'1'}})

參考鏈接:http://chabaoo.cn/article/160401.htm

3.移動端引入外部字體樣式

移動端引入外部樣式,我用的是直接把字體庫的字體下載下來,一般后綴為 .ttf/.otf等。在asset文件下創(chuàng)建 fonts文件,將字體文件全部放入。

再新建一個.css文件,相當于注冊你下載的字體,可以自定義給字體們命名,不過一般還是按照以前的名字。src是文件所在的路徑。

在需要的地方使用就可以了:font-family:"PingFang"

4.使用htmtl2canvas截圖功能,轉(zhuǎn)換成圖片

先下載html2canvas包: cnpm i html2canvas -S / import html2canvas from 'html2canvas';

查看文檔 : 點擊進來直接生成圖片 利用微信長按保存圖片功能來保存

setTimeout(() => { //這里用定時器是因為頁面一加載出來我就展示的是圖片 為了防止圖片還未生成 給點時間
 html2canvas(document.querySelector("#top"), {
 useCORS: true, //是否嘗試使用CORS從服務(wù)器加載圖像 
 logging: false,//刪除打印的日志 
 allowTaint: false //這個和第一個很像 但是不能同時使用 同時使用toDataURL會失效
 }).then(canvas => {
 let imageSrc = canvas.toDataURL("image/jpg"); // 轉(zhuǎn)行img的路徑 
 this.imageSrc = imageSrc; //定義一個動態(tài)的 :src 現(xiàn)在是賦值給src 圖片就會展現(xiàn)
 this.$refs.top.style.display = "none"; // 讓頁面上其他元素消失 只顯示圖片
 });
 }, 1000);

題外話: 當時做這個的時候真的有點懵。官網(wǎng)文檔太少了,當時遇到圖片跨域問題,找了好久,可能是我沒有仔細Jan官網(wǎng)的參數(shù)配置文件。浪費了很多時間,哭哭。

5.使用微信接口(前端部分)

我們用微信SDK接口主要是做的登錄和分享功能,首先是上微信公眾平臺上邊看看,把權(quán)限搞好之后后端配置。前端只需請求得到數(shù)據(jù),在進行一些配置就可以。這里主要介紹分享給朋友和分享到朋友圈功能:

this.code = location.href; //首先獲取code 
if (this.code.lastIndexOf("code=") != -1) {
 (this.code = this.code.substring(
 this.code.lastIndexOf("code=") + 5,
 this.code.lastIndexOf("&state")
 )),
 this.$axios
 .get("*******8?code=".concat(this.code))
 .then(function(t) { //獲取后端傳會來的參數(shù) 
 localStorage.setItem("unionid", t.data.unionid);
 localStorage.setItem("openid", t.data.openid);
 localStorage.setItem("nickname", t.data.nickname);
 localStorage.setItem("headimgurl", t.data.headimgurl);
 });
}
this.url = encodeURIComponent(location.href.split("#/")[0]);//獲取配置的路徑
this.$axios.get(`*********?url=${this.url}`).then(res => {
 this.res = res.data;
 wx.config({
 debug: false, // 開啟調(diào)試模式,
 appId: res.data.appId, // 必填,企業(yè)號的唯一標識,此處填寫企業(yè)號corpid
 timestamp: res.data.timestamp, // 必填,生成簽名的時間戳
 nonceStr: res.data.nonceStr, // 必填,生成簽名的隨機串
 signature: res.data.signature, // 必填,簽名,見附錄1
 jsApiList: [
 "updateAppMessageShareData",
 "updateTimelineShareData",
 "showMenuItems",
 "hideAllNonBaseMenuItem"
 ] // 必填,需要使用的JS接口列表,所有JS接口列表見附錄2
 });
 //參考公眾平臺寫的:
 wx.ready(function() {
 wx.hideAllNonBaseMenuItem();
 wx.showMenuItems({
 menuList: [
 "menuItem:share:appMessage",
 "menuItem:share:timeline",
 "menuItem:favorite"
 ] // 要顯示的菜單項,所有menu項見附錄3
 });
 wx.updateTimelineShareData({
 title: "******", // 分享標題
 desc: "*********", // 分享描述
 link: "**********", // 分享鏈接,該鏈接域名或路徑必須與當前頁面對應(yīng)的公眾號JS安全域名一致
 imgUrl: "******", // 分享圖標
 success: function() {
 ***** 執(zhí)行結(jié)束后執(zhí)行的回調(diào)
 }
 });
 wx.updateAppMessageShareData({
 title: "*******", // 分享標題
 desc: "*********", // 分享描述
 link: "*********", // 分享鏈接,該鏈接域名或路徑必須與當前頁面對應(yīng)的公眾號JS安全域名一致
 imgUrl: "********, // 分享圖標
 success: function() {
 *******
 }
 });
 });
 }

6.移動端屏幕適配

現(xiàn)在我們移動端屏幕適配,我用的是rem,之前也有看到說有一個felxable.js的庫,后來去查,說是有更好的作者放棄了,并且給我們提供了鏈接,哈哈哈哈真的太可愛了。準備抽時間去仔細看看,公司下一個項目又來了,真的加班了好久,為了如期完成項目,完成之后立馬就新開項目,有點心累,這把應(yīng)該是APP了,完全沒有任何經(jīng)驗,嗷嗷只能硬著頭皮做,還是要恰飯的,可憐的應(yīng)屆狗不敢造次。

下面分享一下rem適配的代碼:

//默認調(diào)用一次設(shè)置
 setHtmlFontSize();
 
 function setHtmlFontSize() {
 // 1. 獲取當前屏幕的寬度
 var windowWidth = document.documentElement.offsetWidth;
 // console.log(windowWidth);
 // 2. 定義標準屏幕寬度 假設(shè)375
 var standardWidth = 375;
 // 3. 定義標準屏幕的根元素字體大小 假設(shè)100px 1rem=100px 10px = 0.1rem 1px 0.01rem
 var standardFontSize = 100;
 // 4. 計算當前屏幕對應(yīng)的根元素字體大小
 var nowFontSize = windowWidth / standardWidth * standardFontSize + 'px';
 // console.log(nowFontSize);
 // 5. 把當前計算的根元素的字體大小設(shè)置到html上
 document.querySelector('html').style.fontSize = nowFontSize;
 }
 // 6. 添加一個屏幕寬度變化的事件 屏幕變化就觸發(fā)變化根元素字體大小計算的js 
 window.addEventListener('resize', setHtmlFontSize);

把這段代碼引入到main.js里面,然后使用轉(zhuǎn)換器把px轉(zhuǎn)成rem 就可以了。

7.其他問題匯總

點擊事件點擊多次只執(zhí)行一次:

可以使用.once修飾符 還有很多有用的修飾符,大家有時間可以去看看~~

使用ios輸入框的時候,鍵盤彈起來回遮擋下面的按鈕等元素的事件:

我們可以給input注冊一個失去焦點事件,當失去焦點的時候設(shè)置document.body.scroolTop = 0;

打包項目遇到靜態(tài)資源不展示的現(xiàn)象或者是路徑錯誤:

我用的是vue-cil3,他把配置文件都放在了node_modules中,官方文檔上面有介紹,如果需要修改配置,

就新建一個vue.config.js文件,他會自動的覆蓋之前的文件。主要是修改成: publicPath: "./",

文檔已經(jīng)沒有baseUrl,現(xiàn)在全部使用publicPath,跟著文檔配置就ok了。

結(jié)尾:

我遇到的問題大致就這些,因為項目比較小,所以沒有遇到太多問題。過程真的有點心酸,我獨立解決問題的能力真的很一般,不知道是不是沒有做程序員的潛質(zhì),出現(xiàn)問題就很焦慮,解決了一段時間以后,還是沒有辦法,就會更加焦慮。在上家公司實習(xí)的時候,我們組長指出來這個問題以后,我真的反省了好久。現(xiàn)在這家公司還是在實習(xí),但是前端就一個人,小姐姐人很好,但是不用vue框架,所以遇到問題還是得單獨解決。前端小姐姐是很堅韌的人,遇到問題,真的是一個一個線索的去找,不放棄那種,一開始我們要用flutter,我環(huán)境搭建搞了好久,最后是小姐姐陪我搞好的。真的走到那里都是學(xué)習(xí)的過程。我覺得堅毅真的是世界上特別珍貴的品質(zhì),渴望擁有!!!

相關(guān)文章

  • Vue?關(guān)于$emit與props的使用示例代碼

    Vue?關(guān)于$emit與props的使用示例代碼

    父組件使用 props 把數(shù)據(jù)傳給子組件,子組件使用 $emit 觸發(fā)父組件的自定義事件,今天通過示例給大家詳細介紹下Vue?關(guān)于$emit與props的使用,感興趣的朋友一起看看吧
    2022-03-03
  • 詳解Vue實現(xiàn)直播功能

    詳解Vue實現(xiàn)直播功能

    這篇文章主要介紹了Vue實現(xiàn)直播功能,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-10-10
  • 如何在Vue中使用debouce防抖函數(shù)

    如何在Vue中使用debouce防抖函數(shù)

    本文主要介紹在Vue中使用debouce防抖函數(shù),設(shè)置一個門檻值,表示兩次?Ajax?通信的最小間隔時間。如果在間隔時間內(nèi),發(fā)生新的keydown事件,則不觸發(fā)?Ajax?通信,并且重新開始計時。如果過了指定時間,沒有發(fā)生新的keydown事件再將數(shù)據(jù)發(fā)送出去,這便是debouce防抖函數(shù)
    2021-12-12
  • VUE實現(xiàn)自身整體組件銷毀的示例代碼

    VUE實現(xiàn)自身整體組件銷毀的示例代碼

    這篇文章主要介紹了VUE實現(xiàn)自身整體組件銷毀的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-01-01
  • vue2+element?ui?中的el-table?選中當前行當前行變色的實現(xiàn)代碼

    vue2+element?ui?中的el-table?選中當前行當前行變色的實現(xiàn)代碼

    這篇文章主要介紹了vue2+element?ui?中的el-table?選中當前行當前行變色的實現(xiàn)代碼,本文通過實例代碼給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧
    2024-07-07
  • Vue中前端與后端如何實現(xiàn)交互

    Vue中前端與后端如何實現(xiàn)交互

    這篇文章主要介紹了Vue中前端與后端如何實現(xiàn)交互,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue-music關(guān)于Player播放器組件詳解

    vue-music關(guān)于Player播放器組件詳解

    這篇文章主要為大家詳細介紹了vue-music關(guān)于Player播放器組件的相關(guān)資料,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • Vue input輸入框中的值如何變成黑點問題

    Vue input輸入框中的值如何變成黑點問題

    這篇文章主要介紹了Vue input輸入框中的值如何變成黑點問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • 解決vue 單文件組件中樣式加載問題

    解決vue 單文件組件中樣式加載問題

    這篇文章主要介紹了解決vue 單文件組件中樣式加載問題,文章末尾給大家補充介紹了vue單文件組件中樣式的問題,需要的朋友可以參考下
    2019-04-04
  • Vue3動態(tài)路由(響應(yīng)式帶參數(shù)的路由)變更頁面不刷新的問題解決辦法

    Vue3動態(tài)路由(響應(yīng)式帶參數(shù)的路由)變更頁面不刷新的問題解決辦法

    問題來源是因為我的開源項目Maple-Boot項目的網(wǎng)站前端,因為項目主打的內(nèi)容發(fā)布展示,所以其中的內(nèi)容列表頁會根據(jù)不同的菜單進行渲染不同的路由,本文降介紹Vue3動態(tài)路由變更頁面不刷新的問題解決辦法,需要的朋友可以參考下
    2024-07-07

最新評論