愛鋒貝

 找回密碼
 立即注冊

只需一步,快速開始

扫一扫,极速登录

查看: 1802|回復: 20
打印 上一主題 下一主題
收起左側

一小時開發(fā)一個簡單的微信小程序

[復制鏈接]

1356

主題

1397

帖子

5663

積分

Rank: 8Rank: 8

跳轉到指定樓層
樓主
發(fā)表于 2023-2-26 07:29:05 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式

一鍵注冊,加入手機圈

您需要 登錄 才可以下載或查看,沒有帳號?立即注冊   

x
定制小程序、畢設、stitp請私信。
云開發(fā)請參考這個demo

雖然不是專業(yè)做微信小程序的,但是由于無聊做一個簡單的demo了解一下開發(fā)流程還是可以的。 這次做了一個手機號碼歸屬地查詢的小程序。做出來的實物如圖:


    理論上也很簡單,就是找一個可查歸屬地的API進行接口調用,做一個返回數(shù)據(jù)展示而已。 只要你會JavaScript,真的是分分鐘上手,但是小程序上線還是比較繁瑣的,而且要學著用微信小程序的IDE 所謂開發(fā)一小時,上線等幾年。
    關于微信小程序的技術文檔見官方網(wǎng)站:http://nginx.org/en/ 個人覺得寫得異常細致。

  • 1、申請賬號

        申請賬號的地址 https://mp.weixin.qq.com/wxopen/waregister?action=step1

        微信這點比較坑,可能由于管理需求。個人開發(fā)的話,雖然一個人名下可以有五個小程序,但一個郵箱只能對應管理一個小程序。 如果你想開發(fā)多個,還得多用幾個郵箱,非常麻煩。

        按流程注冊完成之后,會有一個AppID(小程序ID),這個ID很重要。在IDE創(chuàng)建項目和項目上線都是需要的。



  • 2、安裝開發(fā)者工具IDE

    https://developers.weixin.qq.com/miniprogram/dev/devtools/download.html

         我這里用的是穩(wěn)定版 Stable Build。微信的IDE界面還行,但是拓展功能很差,快捷鍵支持的也不多,不是特別好用 。我大致給畫一下區(qū)域



  • 3、基本認識

         這里我們首先要認識四種文件類型 json、js、wxml、wxss。
      json和js大家都很熟悉了,微信小程序用json存儲數(shù)據(jù)或是寫配置信息等。js用來寫JavaScript。 令人好奇的是wxml、wxss到底是什么東西,大家都很熟悉HTML + CSS + JS的模式。實際上wxml就是html,而wxss就是寫樣式的css。 wxml也有類似vue的那種{{}}綁定數(shù)據(jù)的方法。wxss增加了一個rpx的計量單位,方便手機操作。我發(fā)現(xiàn)這套模式對有的原生html寫法 有很多不兼容的地方,還得考慮安卓和ios的兼容性問題等。我們只是做一個demo的話、暫時不去學這些東西,就當作HTML + CSS + JS的模式 去寫吧,遇到具體的問題再具體解決。

    微信小程序有一個主配置文件就是app.json,我們可以看出來是配置index和背景樣式之類的東西,這里我們暫時不用改這些。



  • 4、開發(fā)

        終于講到開發(fā)內(nèi)容了,我們看上圖的app.json,就知道index對應的目錄為 pages/index/index,也就是打開小程序的第一個頁面。于是我們首先來看這個html怎么寫,哦、不,wxml怎么寫,非常簡單的寫一個。



wxml也是支持那種類似vue雙括號{{}}綁定value的寫法,我標的很詳細。寫好之后在js的data{}里聲明數(shù)據(jù)就輕松實現(xiàn)js對綁定value的操作了。


     樣式方面可以自己在wxss里面設置,無非就是改view的class長寬高,這里我主要說一下背景圖片的樣式:
page{
    height:100%;
  }
  .background {
    width: 100%;
    height: 100%;
    position:fixed;
    background-size:100% 100%;
    z-index: -1;
  }    最后就是js的寫法了,之前我們在查詢按鈕綁定了一個事件btnclick,我們只需要聲明一個點擊調用API的函數(shù)即可。 查詢手機號碼歸屬的免費API非常多,讀者可自行查閱。這里用了wx.request來發(fā)起請求:
btnclick:function(){
       var iPhone = this.data.iphones;
       var that = this;
       var key = "調用API的key,不用key可以不寫";
       if(iphone != null && iphone != ''){
       wx.request({
         url: 'https://apis.juhe.cn/mobile/get?phone='+iphone+'&key='+key, //API的URL
         data: {
         },
         header: {
           'content-type': 'application/json' // 默認值
         },
         success (res) {
           console.log(res.data);
             if(res.data.result == null){
               that.setData({
                 province: "號碼不存在",
                 city:"",
                 company: ""
                })
             }else{
               if(res.data.result.city == res.data.result.province){ //這里是防止出現(xiàn) 北京北京聯(lián)通的情況,直轄市用法
                 that.setData({
                   province: res.data.result.province,
                   city: "",
                   company: res.data.result.company,
                  })
               }else{
                 that.setData({
                   province: res.data.result.province,
                   city: res.data.result.city,
                   company: res.data.result.company,
                  })
               }
             }
           }
       })      
       }
   },    有些重要的點說一下,首先是這里必須要用var that = this;的定義去用this。 然后不同的接口返回的res.data的json格式肯定不同,請自行調整。
重要的一點每個微信小程序需要事先設置通訊域名,小程序只可以跟指定的域名進行網(wǎng)絡通信。也就是說,你不配的話這個接口是調用不通的
    1、服務器域名請在 「小程序后臺-開發(fā)-開發(fā)設置-服務器域名」 中進行配置,配置時需要注意:
    2、域名只支持 https (wx.request、wx.uploadFile、wx.downloadFile) 和 wss (wx.connectSocket) 協(xié)議;
    3、域名不能使用 IP 地址(小程序的局域網(wǎng) IP 除外)或 localhost;
    4、可以配置端口,如 https://myserver.com:8080,但是配置后只能向 https://myserver.com:8080 發(fā)起請求。如果向 https://myserver.com、https://myserver.com:9091 等 URL 請求則會失敗。
    5、如果不配置端口。如 https://myserver.com,那么請求的 URL 中也不能包含端口,甚至是默認的 443 端口也不可以。如果向 https://myserver.com:443 請求則會失敗。
    6、域名必須經(jīng)過 ICP 備案;
    7、出于安全考慮,http://api.weixin.qq.com 不能被配置為服務器域名,相關API也不能在小程序內(nèi)調用。 開發(fā)者應將 AppSecret 保存到后臺服務器中,通過服務器使用 getAccessToken 接口獲取 access_token,并調用相關 API;
    8、對于每個接口,分別可以配置最多 20 個域名。


* 5、上傳代碼及版本管理

    小程序寫好之后進行模擬器測試的同時,一定要真機調試一下,看一下有沒有兼容性的問題。IDE集成了真機調試的功能。
    微信小程序的代碼有四個版本,分別是開發(fā)版、體驗版、審核版和線上版
     當你把開發(fā)板上傳之后就生成了體驗版,可用來進行測試。測試無誤之后 即可發(fā)布審核版,在微信官方審核之后,即可上線成為線上版本。審核大約在幾天時間。

本人授權維權騎士對我發(fā)布文章的版權行為進行追究與維權。未經(jīng)本人許可,不可擅自轉載或用于其他商業(yè)用途。

-----------------------------
精選高品質二手iPhone,上愛鋒貝APP

0

主題

49

帖子

3

積分

Rank: 1

沙發(fā)
發(fā)表于 2023-2-26 08:45:47 | 只看該作者
大佬!
精選高品質二手iPhone,上愛鋒貝APP

0

主題

46

帖子

3

積分

Rank: 1

板凳
發(fā)表于 2023-2-26 10:06:25 | 只看該作者
厲害
精選高品質二手iPhone,上愛鋒貝APP

0

主題

52

帖子

3

積分

Rank: 1

地板
發(fā)表于 2023-2-26 12:01:59 | 只看該作者
可以掛下源碼(去除了敏感信息)嗎?
精選高品質二手iPhone,上愛鋒貝APP

0

主題

53

帖子

3

積分

Rank: 1

5
發(fā)表于 2023-2-26 13:39:12 | 只看該作者
沒啥敏感信息、可以。
精選高品質二手iPhone,上愛鋒貝APP

0

主題

41

帖子

196

積分

Rank: 1

6
發(fā)表于 2023-2-26 15:23:46 | 只看該作者
這...除了歸屬地api啥也沒有。10分鐘就閑多了,還一個小時
精選高品質二手iPhone,上愛鋒貝APP

0

主題

45

帖子

3

積分

Rank: 1

7
發(fā)表于 2023-2-26 16:54:26 | 只看該作者
我覺著你一分鐘就可以[贊同][贊同][贊同]
精選高品質二手iPhone,上愛鋒貝APP

0

主題

42

帖子

0

積分

Rank: 1

8
發(fā)表于 2023-2-26 18:32:21 | 只看該作者
請問一下接入API可以用微信提供的云開發(fā)嗎?
精選高品質二手iPhone,上愛鋒貝APP

0

主題

38

帖子

3

積分

Rank: 1

9
發(fā)表于 2023-2-26 20:07:10 | 只看該作者
兄弟我能加下你微信嗎?我想做一個小程序。
精選高品質二手iPhone,上愛鋒貝APP

0

主題

38

帖子

3

積分

Rank: 1

10
發(fā)表于 2023-2-26 21:43:04 | 只看該作者
完全看不懂[大哭]
精選高品質二手iPhone,上愛鋒貝APP
您需要登錄后才可以回帖 登錄 | 立即注冊   

本版積分規(guī)則

QQ|Archiver|手機版|小黑屋|愛鋒貝 ( 粵ICP備16041312號-5 )

GMT+8, 2025-2-26 04:05

Powered by Discuz! X3.4

© 2001-2013 Discuz Team. 技術支持 by 巔峰設計.

快速回復 返回頂部 返回列表