塘下鎮(zhèn)八分鐘帶你入門(mén)微信小程序開(kāi)發(fā)
閱讀 43334 · 發(fā)布日期 2020-08-24 17:26 · 溫州優(yōu)光網(wǎng)絡(luò)科技有限公司|建站|APP小程序制作|做網(wǎng)站SEO推廣優(yōu)化注冊(cè)微信小程序如果你還沒(méi)有微信公眾平臺(tái)的賬號(hào),請(qǐng)先進(jìn)入微信公眾平臺(tái)首頁(yè),點(diǎn)擊 “立即注冊(cè)” 按鈕進(jìn)行注冊(cè)。
注冊(cè)的賬號(hào)類(lèi)型可以是訂閱號(hào)、服務(wù)號(hào)、小程序以及企業(yè)微信,我們選擇 “小程序” 即可。
接著填寫(xiě)賬號(hào)信息,需要注意的是,填寫(xiě)的郵箱必須是未被微信公眾平臺(tái)注冊(cè)、未被個(gè)人微信號(hào)綁定的郵箱,而且每個(gè)郵箱僅能申請(qǐng)一個(gè)小程序。
激活郵箱之后,選擇主體類(lèi)型為 “個(gè)人類(lèi)型”,并按要求登記主體信息。
主體信息提交后不可修改,該主體將成為你使用微信公眾平臺(tái)各項(xiàng)服務(wù)和功能的唯一法律主體與締約主體,在后續(xù)開(kāi)通其他業(yè)務(wù)功能時(shí)不得變更或修改。
一切 OK 就可以直接進(jìn)入小程序的管理平臺(tái)了。
如果直接跳轉(zhuǎn)失敗,也可以從微信公眾平臺(tái)上手動(dòng)登錄。
填寫(xiě)小程序的基本信息,包括名稱(chēng)、圖標(biāo)、描述等。
提交成功之后,再添加開(kāi)發(fā)者。
開(kāi)發(fā)者默認(rèn)為管理員,我們也可以從這里新增綁定開(kāi)發(fā)者,這是管理員才有權(quán)限的操作。
然后在左側(cè)導(dǎo)航欄點(diǎn)擊 “設(shè)置”,找到開(kāi)發(fā)設(shè)置,獲得小程序的 AppID。
微信開(kāi)發(fā)者工具下載微信web開(kāi)發(fā)者工具,根據(jù)自己的操作系統(tǒng)下載對(duì)應(yīng)的安裝包進(jìn)行安裝即可。
打開(kāi)開(kāi)發(fā)者工具,用微信掃碼登錄開(kāi)發(fā)者工具,準(zhǔn)備開(kāi)發(fā)你的第一個(gè)小程序吧!第一個(gè)小程序新建項(xiàng)目打開(kāi)開(kāi)發(fā)者工具,選擇 “小程序項(xiàng)目”,點(diǎn)擊右下角的 “+” 新建項(xiàng)目。
選擇一個(gè)空的文件夾作為項(xiàng)目目錄,填入剛剛的 AppID,再填寫(xiě)一個(gè)項(xiàng)目名稱(chēng),比如我這里叫做 GoZeroWaster。
點(diǎn)擊 “確定” 進(jìn)入工具主界面。
項(xiàng)目目錄結(jié)構(gòu)微信小程序的基本文件構(gòu)造和項(xiàng)目目錄結(jié)構(gòu)說(shuō)明如下:
. ├── app.js # 小程序的邏輯文件 ├── app.json # 小程序的配置文件 ├── app.wxss # 全局公共樣式文件 ├── pages # 存放小程序的各個(gè)頁(yè)面 │ ├── index # index頁(yè)面 │ │ ├── index.js # 頁(yè)面邏輯 │ │ ├── index.wxml # 頁(yè)面結(jié)構(gòu) │ │ └── index.wxss # 頁(yè)面樣式表 │ └── logs # logs頁(yè)面 │ ├── logs.js # 頁(yè)面邏輯 │ ├── logs.json # 頁(yè)面配置 │ ├── logs.wxml # 頁(yè)面結(jié)構(gòu) │ └── logs.wxss # 頁(yè)面樣式表 ├── project.config.json └── utils └── util.js根目錄下有3個(gè)文件:
app.js、app.json、app.wxss,小程序必須有這3個(gè)描述 APP 的文件,并放在根目錄下。
這3個(gè)是應(yīng)用程序級(jí)別的文件,與之平行的還有一個(gè) pages 文件夾,用來(lái)存放小程序的各個(gè)頁(yè)面。
我們可以和 web 前端開(kāi)發(fā)技術(shù)做個(gè)類(lèi)比:
wxml 類(lèi)似于 HTML 文件,用來(lái)編寫(xiě)頁(yè)面的標(biāo)簽和骨架,但里面只能用小程序自己封裝的組件;wxss 類(lèi)似于 CSS 文件,用來(lái)編寫(xiě)頁(yè)面樣式,只是把 css 文件換成了 wxss 文件;js 文件類(lèi)似于前端編程中的 JavaScript 文件,用來(lái)編寫(xiě)小程序的頁(yè)面邏輯;json 文件用來(lái)配置頁(yè)面的樣式和行為。
目標(biāo)成果我們先來(lái)看看最終的目標(biāo)和成果,很簡(jiǎn)單,一共兩頁(yè):
(為了讓廣大程序員也能保護(hù)環(huán)境和熱愛(ài)生活,我特意選了 “零垃圾生活” 主題來(lái)做 Demo)步驟分解Demo 代碼下載:
https://gitee.com/luhuadong/Web_Learning/tree/master/WeChat/GoZeroWaster分解目標(biāo)成果:
個(gè)人中心生活指南模擬彈窗預(yù)覽圖片頁(yè)頭頁(yè)尾在目標(biāo)成果預(yù)覽中我們看到,兩個(gè)頁(yè)面都有共同的部分 —— 頁(yè)頭和頁(yè)尾。
所以在構(gòu)建頁(yè)面內(nèi)容之前,我們先把頁(yè)頭和頁(yè)尾處理好。
我們很容易猜到,這兩部分屬于小程序的全局配置,因此需要修改 app.json 文件。
最初的內(nèi)容如下:
{
"pages":[ "pages/index/index", "pages/logs/logs" ], "window":{
"backgroundTextStyle": "light", "navigationBarBackgroundColor": "#fff", "navigationBarTitleText": "WeChat", "navigationBarTextStyle": "balack" }
}
pages 屬性用來(lái)設(shè)置頁(yè)面路徑,它是一個(gè)數(shù)組,每一項(xiàng)都是字符串來(lái)指定小程序由哪些頁(yè)面組成。
數(shù)組的第一項(xiàng)代表小程序的初始頁(yè)面。
小程序中新增或減少頁(yè)面,都需要對(duì) pages 數(shù)組進(jìn)行修改。
window 屬性用于設(shè)置小程序的狀態(tài)欄、導(dǎo)航條、標(biāo)題、窗口背景色。
我們把頁(yè)頭的標(biāo)題和顏色修改一下,頁(yè)尾部分我們做一個(gè) tab 欄來(lái)切換頁(yè)面,這個(gè)屬性叫做 tabBar,代碼如下:
{
"pages":[ "pages/index/index", "pages/logs/logs" ], "window":{
"backgroundTextStyle":"light", "navigationBarBackgroundColor": "#2f2f8f", "navigationBarTitleText": "GoZeroWaste", "navigationBarTextStyle":"white" }
, "tabBar":{
"color": "#bfc1ab", "selectedColor": "#13b11c", "backgroundColor": "#1f1f4f", "list": [ {
"pagePath": "pages/index/index", "iconPath": "image/icon_component.png", "selectedIconPath": "image/icon_component_HL.png", "text": "個(gè)人中心" }
, {
"pagePath": "pages/details/details", "iconPath": "image/icon_API.png", "selectedIconPath": "image/icon_API_HL.png", "text": "生活指南" }
] }
}
(所用到的圖片放在項(xiàng)目的 image 目錄,你也可以使用自己的圖片)這里用到幾個(gè) tabBar 的屬性是 color、selectedColor、backgroundColor 和 list,list 是一個(gè)數(shù)組,主要用于設(shè)定導(dǎo)航的路徑。
CTRL + S 保存之后,模擬器就會(huì)自動(dòng)刷新,馬上可以看到效果。
個(gè)人中心簡(jiǎn)單起見(jiàn),我們就在 pages/index 目錄下實(shí)現(xiàn) “個(gè)人中心” 頁(yè)面好了。
雙擊打開(kāi) index.wxml,初始內(nèi)容如下:
{
userInfo.nickName}
}
{
motto}
}
我們把 “Hello World” 部分注釋掉,增加我們希望顯示的內(nèi)容:
{
userInfo.nickName}
}
{
company}
}
>{
{
position}
}
>{
{
lesson}
}
{
company}
}
、{
{
position}
}
和 {
{
lesson}
}
作為占位符,用法類(lèi)似于 Django 的模板語(yǔ)言。
當(dāng)然也可以直接用相應(yīng)的字符來(lái)替換它,只不過(guò)我們想沿用 {
{
motto}
}
的做法,讓你知道在哪里修改這些數(shù)據(jù)。
沒(méi)錯(cuò),就是在 index.js 文件:
Page({
data: {
motto: '
Hello World'
, company: "GoZeroWaste", lesson: "21天零垃圾生活指南", position: "垃圾魔法師", /* ... */ }
wxml 文件中的
,而
當(dāng)然,可用用
>{
{
lesson}
}
mode='
widthFix'
src='
../../image/GoZeroWaste.jpg'
>
接下來(lái)還需要修改 index.wxss 文件來(lái)設(shè)置樣式:
/**index.wxss**/.userinfo {
display: flex;
flex-direction: column;
align-items: center;
}
.userinfo-avatar {
width: 128rpx;
height: 128rpx;
margin: 20rpx;
border-radius: 50%;
}
.userinfo-nickname {
color: #aaa;
}
.usermotto {
margin-top: 200px;
}
.ID_Badge {
padding-top: 20rpx;
color: blue;
}
.ID_info {
display: flex;
flex-direction: column;
align-items: center;
}
.pics {
width: 400rpx;
}
保存刷新,“個(gè)人中心” 頁(yè)面就完成了。
生活指南原來(lái)的項(xiàng)目中 pages 目錄下只有 index 和 logs 兩個(gè)目錄,因此我們還需要為第二個(gè)頁(yè)面創(chuàng)建一個(gè)目錄。
創(chuàng)建頁(yè)面有兩種方法:
在目錄結(jié)構(gòu)的 pages 圖表上,新建目錄,然后在目錄下逐一創(chuàng)建頁(yè)面構(gòu)成文件在 app.json 下,直接添加建議采用第二種方法,修改 app.json 文件:
{
"pages":[
"pages/index/index",
"pages/logs/logs",
"pages/details/details"
]保存刷新之后就會(huì)發(fā)現(xiàn),目錄結(jié)構(gòu)里自動(dòng)創(chuàng)建了這一頁(yè)。
對(duì)應(yīng)的,也要修改 app.json 中的 tabBar 的鏈接(實(shí)際上我們已經(jīng)做了):
{
"pagePath": "pages/details/details",
"iconPath": "image/icon_API.png",
"selectedIconPath": "image/icon_API_HL.png",
"text": "生活指南"
}
然后修改 details.wxml 設(shè)置這一頁(yè)的標(biāo)題:
>
/* pages/details/details.wxss */
.title {
display: flex;
flex-direction: column;
align-items: center;
margin-top: 40rpx;
margin-bottom: 40rpx;
font-size: 40rpx;
}
這個(gè)頁(yè)面是一個(gè)列表展示的頁(yè)面,我們先在 details.js 文件中準(zhǔn)備好數(shù)據(jù):
// pages/details/details.jsPage({
/**
* 頁(yè)面的初始數(shù)據(jù)
*/
data: {
showModalStatus: false,
list: [
{
id: 0,
name : "寫(xiě)一篇《垃圾日記》",
introduce: "零垃圾并不是一項(xiàng)宏大的工程,而是由日常生活中一個(gè)個(gè)小小的習(xí)慣和選擇組成的。
最難的,是邁出第一步。
",
src: '
../../image/day01.jpg'
,
showModalStatus: false,
catalog: [
{
section: "1. xxx" }
,
{
section: "2. xxx" }
,
{
section: "3. xxx" }
,
{
section: "4. xxx" }
,
]
}
,
{
id: 1,
name: "帶上自己的購(gòu)物袋",
introduce: "在我們家,當(dāng)時(shí)垃圾桶里最多的就是塑料袋,而這些袋子跟著我回家后,都幾乎難逃被丟進(jìn)垃圾桶的命運(yùn)。
",
src: '
../../image/day02.jpg'
,
showModalStatus: false,
catalog: [
{
section: "1. xxx" }
,
{
section: "2. xxx" }
,
{
section: "3. xxx" }
,
{
section: "4. xxx" }
,
]
}
,
/* 省略 */
]
}
接下來(lái)我們要使用列表渲染(wx:for)的方法將這些數(shù)據(jù)綁定一個(gè)數(shù)組,并在頁(yè)面上重復(fù)渲染。
修改 details.wxml 文件:
src="{
{
item.src}
}
">
{
item.name}
}
{
item.introduce}
}
修改 details.wxss 文件添加樣式:
.lesson {
height: 190rpx;
padding-left: 20rpx;
}
.lessonPic {
position: absolute;
height: 150rpx;
width: 150rpx;
}
.lessonName {
position: absolute;
margin-left: 220rpx;
font-size: 35rpx;
}
.lessonIntroduce {
position: absolute;
margin-left: 220rpx;
margin-top: 60rpx;
margin-right: 20rpx;
color: rgb(185, 161, 161);
font-size: 28rpx;
}
好啦,第二個(gè)頁(yè)面也完成了。
模擬彈窗接下來(lái)我們要在 “生活指南” 頁(yè)面模擬一個(gè)彈窗的效果,正常的時(shí)候不顯示,只有在點(diǎn)擊的時(shí)候才出現(xiàn),摁下面的 “確定” 就會(huì)消失。
完了實(shí)現(xiàn)這個(gè)功能,我們要在組件中綁定一個(gè)事件處理函數(shù) bindtap,點(diǎn)擊該組件的時(shí)候,小程序會(huì)在該頁(yè)面對(duì)應(yīng)的 Page 中找到相應(yīng)的事件處理函數(shù)。
我們先在 details.js 中為每一列數(shù)據(jù)里引入一個(gè) boolean 變量 showModalStatus 來(lái)描述對(duì)應(yīng)的彈窗狀態(tài),并且初始值為 false,表示不顯示。
同時(shí)外層也增加一個(gè)初始值為 false 的 showModalStatus 變量實(shí)現(xiàn)遮罩效果。
如下:
data: {
showModalStatus: false,
list: [
{
id: 0,
name : "寫(xiě)一篇《垃圾日記》",
introduce: "零垃圾并不是一項(xiàng)宏大的工程,而是由日常生活中一個(gè)個(gè)小小的習(xí)慣和選擇組成的。
最難的,是邁出第一步。
",
src: '
../../image/day01.jpg'
,
showModalStatus: false,
catalog: [
{
section: "1. xxx" }
,
{
section: "2. xxx" }
,
{
section: "3. xxx" }
,
{
section: "4. xxx" }
,
]
}
然后在 details.wxml 中插入彈窗,并用條件渲染(wx:if)來(lái)判斷是否渲染(顯示)彈窗。
同時(shí)為每一個(gè) item 添加 data-statu 來(lái)表示彈窗的狀態(tài)。
如下:
data-statu='
open'
id="{
{
item.id}
}
">
src="{
{
item.src}
}
">
{
item.name}
}
{
item.introduce}
}
wx:if='
{
{
item.showModalStatus}
}
'
id='
{
{
item.id}
}
'
>
{
item.name}
}
>
wx:for='
{
{
item.catalog}
}
'
wx:for-item='
catalog'
wx:key='
id'
>
{
{
catalog.section}
}
bindtap='
powerDrawer'
data-statu='
close'
id='
{
{
item.id}
}
'
>確定
data-statu='
close'
wx:if='
{
{
showModalStatus}
}
'
>
powerDrawer: function (e) {
console.log("clicked");
var currentStatu = e.currentTarget.dataset.statu;
var index = e.currentTarget.id;
// 關(guān)閉
if (currentStatu == '
close'
) {
this.data.list[index].showModalStatus = false;
this.setData({
showModalStatus: false,
list: this.data.list,
}
);
}
// 顯示
if (currentStatu == '
open'
) {
this.data.list[index].showModalStatus = true;
this.setData({
showModalStatus: true,
list: this.data.list,
}
);
}
}
,最后在 details.wxss 設(shè)置一下彈窗和遮罩層的樣式:
.drawer_box {
width: 650rpx;
overflow: hidden;
position: fixed;
top: 50%;
z-index: 1001;
background: #FAFAFA;
margin: -150px 50rpx 0 50rpx;
}
.drawer_content {
border-top: 1.5px solid #E8E8EA;
height: 210px;
overflow-y: scroll;
/* 超出父盒子高度可滾動(dòng) */
}
.btn_ok {
padding: 10px;
font: 20px "microsoft yahei";
text-align: center;
border-top: 1.5px solid #E8E8EA;
color: #3CC51F;
}
.drawer_screen {
width: 100%;
height: 100%;
position: fixed;
top: 0;
left: 0;
z-index: 1000;
background: black;
opacity: 0.5;
overflow: hidden;
}
OK,模擬彈窗也實(shí)現(xiàn)了。
預(yù)覽圖片最后一步就是在第一個(gè)頁(yè)面實(shí)現(xiàn)圖片預(yù)覽和圖片保存的功能,在 index.wxml 中為圖片添加一個(gè)點(diǎn)擊事件 previewImage。
mode='
widthFix'
src='
../../image/GoZeroWaste.jpg'
bindtap='
previewImage'
>
如下:
Page({
data: {
motto: '
Hello World'
,
company: "GoZeroWaste",
lesson: "21天零垃圾生活指南",
position: "垃圾魔法師",
imgalist: ['
https://img-blog.csdnimg.cn/20190109104518898.jpg'
],
userInfo: {
}
,
hasUserInfo: false,
canIUse: wx.canIUse('
button.open-type.getUserInfo'
)
}
,
previewImage: function (e) {
wx.previewImage({
current: this.data.imgalist, // 當(dāng)前顯示圖片的http鏈接
urls: this.data.imgalist // 需要預(yù)覽的圖片http鏈接列表
}
)
}
,大功告成,點(diǎn)擊開(kāi)發(fā)者工具中的 “預(yù)覽”,使用微信掃描生成的二維碼即可在手機(jī)端查看。
教程就到這里,希望大家可以對(duì)微信小程序有所了解。
本文轉(zhuǎn)自:
https://luhuadong.blog.csdn.net/article/details/86181251推薦教程:
《微信小程序》以上就是八分鐘帶你入門(mén)微信小程序開(kāi)發(fā)的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注php中文網(wǎng)其它相關(guān)文章!
微信
分享相關(guān)標(biāo)簽:
微信小程序開(kāi)發(fā)本文轉(zhuǎn)載于:
CSDN,如有侵犯,請(qǐng)聯(lián)系[email protected]刪除
上一篇:
小程序new Date()方法失效怎么辦
下一篇:
小程序頁(yè)面間傳遞數(shù)據(jù)的方式相關(guān)文章相關(guān)視頻小程序開(kāi)發(fā)經(jīng)驗(yàn)的總結(jié)微信小程序開(kāi)發(fā)中var that =this的基本...微信小程序開(kāi)發(fā)初次體驗(yàn)新手必備的微信小程序開(kāi)發(fā)指南八分鐘帶你入門(mén)微信小程序開(kāi)發(fā)微信小程序開(kāi)發(fā)工具的安裝認(rèn)識(shí)小程序開(kāi)發(fā)工具
為您推薦
- 百度智能小程序SWAN 視圖基礎(chǔ)數(shù)據(jù)綁定怎么做 2020-08-24
- 百度智能小程序SWAN 視圖是什么? 2020-08-24
- 百度智能小程序啟動(dòng)頁(yè)面的代碼如何設(shè)置 2020-08-24
- 百度智能小程序SWAN 生命周期是什么 2020-08-24
- 百度智能小程序如何配置全局?jǐn)?shù)據(jù) 2020-08-24
- 百度智能小程序?window、tabBar如何優(yōu)化和調(diào)整 2020-08-24
- 百度智能小程序?pages是什么 2020-08-24
- 百度智能小程序配置界面、路徑如何優(yōu)化 2020-08-24