成人av国产,国产伦精品一区二区三区免费,女同一区二区 http://www.573732.com Thu, 13 Dec 2018 03:19:10 +0000 zh-Hans hourly 1 https://wordpress.org/?v=6.4.5 http://www.573732.com/wp-content/uploads/2018/10/cropped-xiaochengxu-32x32.png 小程序教程 – 微信小程序觀察網(wǎng) http://www.573732.com 32 32 微信小程序小白教程 http://www.573732.com/1882.html Thu, 13 Dec 2018 03:19:10 +0000 http://www.573732.com/?p=1882 ? ??2018年,是小程序發(fā)展最火爆的一年。走到大街小巷不管是開店鋪的還是開超市的還是賣修鞋。都想擠破頭做一個(gè)屬于自己的小程序。但對(duì)于一個(gè)小白來說的話,自己開…

微信小程序小白教程最先出現(xiàn)在微信小程序觀察網(wǎng)。

]]>
? ??2018年,是小程序發(fā)展最火爆的一年。走到大街小巷不管是開店鋪的還是開超市的還是賣修鞋。都想擠破頭做一個(gè)屬于自己的小程序。但對(duì)于一個(gè)小白來說的話,自己開發(fā)一個(gè)小程序多少有點(diǎn)困難。下面就和大家分享一下微信小程序小白教程。

?第一步:獲取微信小程序的AppID

首先,你要注冊(cè)一個(gè)微信小程序賬號(hào)。登錄進(jìn)入,在微信公眾號(hào)里面進(jìn)入設(shè)置-開發(fā)者設(shè)置里查看微信小程序的AppID了。

如果你注冊(cè)時(shí)綁定的不是管理員微信號(hào),你可以進(jìn)入小程序,“綁定開發(fā)者”??梢栽凇坝脩羯矸荨?“開發(fā)者”模塊,綁定上需要體驗(yàn)該小程序的微信號(hào)。

微信小程序的AppID

第二步:創(chuàng)建項(xiàng)目

? 創(chuàng)建項(xiàng)目可以通過開發(fā)者工具,來完成小程序的創(chuàng)建和代碼編輯

小程序項(xiàng)目

? 我們需要通過開發(fā)者工具,來完成小程序創(chuàng)建和代碼編輯。

?? ?開發(fā)者工具安裝完成后,打開并使用微信掃碼登錄。選擇創(chuàng)建“項(xiàng)目”,填入上文獲取到的AppID,設(shè)置一個(gè)本地項(xiàng)目的名稱(非小程序名稱),比如“我的第一個(gè)項(xiàng)目”,并選擇一個(gè)本地的文件夾作為代碼存儲(chǔ)的目錄,點(diǎn)擊“新建項(xiàng)目”就可以了。

? 為方便初學(xué)者了解微信小程序的基本代碼結(jié)構(gòu),在創(chuàng)建過程中,如果選擇的本地文件夾是個(gè)空文件夾,開發(fā)者工具會(huì)提示,是否需要?jiǎng)?chuàng)建一個(gè)quick start項(xiàng)目。選擇“是”,開發(fā)者工具會(huì)幫助我們?cè)陂_發(fā)目錄里生成一個(gè)簡單的demo。

?? ? 項(xiàng)目創(chuàng)建成功后,我們就可以點(diǎn)擊該項(xiàng)目,進(jìn)入并看到完整的開發(fā)者工具界面,點(diǎn)擊左側(cè)導(dǎo)航,在“編輯”里可以查看和編輯我們的代碼,在“調(diào)試”里可以測試代碼并模擬小程序在微信客戶端效果,在“項(xiàng)目”里可以發(fā)送到手機(jī)里預(yù)覽實(shí)際效果。

3. 編寫代碼

創(chuàng)建小程序?qū)嵗?/b>

?? ?點(diǎn)擊開發(fā)者工具左側(cè)導(dǎo)航的“編輯”,我們可以看到這個(gè)項(xiàng)目,已經(jīng)初始化并包含了一些簡單的代碼文件。最關(guān)鍵也是必不可少的,是app.js、app.json、app.wxss這三個(gè)。其中,.js后綴的是腳本文件,.json后綴的文件是配置文件,.wxss后綴的是樣式表文件。微信小程序會(huì)讀取這些文件,并生成小程序?qū)嵗?/p>

? 下面我們簡單了解這三個(gè)文件的功能,方便修改以及從頭開發(fā)自己的微信小程序。

? app.js是小程序的腳本代碼。我們可以在這個(gè)文件中監(jiān)聽并處理小程序的生命周期函數(shù)、聲明全局變量。調(diào)用MINA提供的豐富的API,如本例的同步存儲(chǔ)及同步讀取本地?cái)?shù)據(jù)。想了解更多可用API,可參考API文檔

//app.js

App({

onLaunch: function () {

//調(diào)用API從本地緩存中獲取數(shù)據(jù)

var logs = wx.getStorageSync(‘logs’) || []

logs.unshift(Date.now())

wx.setStorageSync(‘logs’, logs)

},

getUserInfo:function(cb){

var that = this;

if(this.globalData.userInfo){

typeof cb == “function” && cb(this.globalData.userInfo)

}else{

//調(diào)用登錄接口

wx.login({

success: function () {

wx.getUserInfo({

success: function (res) {

that.globalData.userInfo = res.userInfo;

typeof cb == “function” && cb(that.globalData.userInfo)

}

})

}

});

}

},

globalData:{

userInfo:null

}

})

? app.json是對(duì)整個(gè)小程序的全局配置。我們可以在這個(gè)文件中配置小程序是由哪些頁面組成,配置小程序的窗口背景色,配置導(dǎo)航條樣式,配置默認(rèn)標(biāo)題。注意該文件不可添加任何注釋。更多可配置項(xiàng)可參考配置詳解

{

“pages”:[

“pages/index/index”,

“pages/logs/logs”

],

“window”:{

“backgroundTextStyle”:”light”,

“navigationBarBackgroundColor”: “#fff”,

“navigationBarTitleText”: “WeChat”,

“navigationBarTextStyle”:”black”

}

}

? app.wxss是整個(gè)小程序的公共樣式表。我們可以在頁面組件的class屬性上直接使用app.wxss中聲明的樣式規(guī)則。

/**app.wxss**/

.container {

height: 100%;

display: flex;

flex-direction: column;

align-items: center;

justify-content: space-between;

padding: 200rpx 0;

box-sizing: border-box;

}

創(chuàng)建頁面

? 在這個(gè)教程里,我們有兩個(gè)頁面,index頁面和logs頁面,即歡迎頁和小程序啟動(dòng)日志的展示頁,他們都在pages目錄下。微信小程序中的每一個(gè)頁面的【路徑+頁面名】都需要寫在app.json的pages中,且pages中的第一個(gè)頁面是小程序的首頁。

? 每一個(gè)小程序頁面是由同路徑下同名的四個(gè)不同后綴文件的組成,如:index.js、index.wxml、index.wxss、index.json。.js后綴的文件是腳本文件,.json后綴的文件是配置文件,.wxss后綴的是樣式表文件,.wxml后綴的文件是頁面結(jié)構(gòu)文件。

? index.wxml是頁面的結(jié)構(gòu)文件:

<!–index.wxml–>

<view class=”container”>

<view ?bindtap=”bindViewTap” class=”userinfo”>

<image class=”userinfo-avatar” src=”{{userInfo.avatarUrl}}” background-size=”cover”></image>

<text class=”userinfo-nickname”>{{userInfo.nickName}}</text>

</view>

<view class=”usermotto”>

<text class=”user-motto”>{{motto}}</text>

</view>

</view>

? 本例中使用了<view/>、<image/>、<text/>來搭建頁面結(jié)構(gòu),綁定數(shù)據(jù)和交互處理函數(shù)。

? index.js是頁面的腳本文件,在這個(gè)文件中我們可以監(jiān)聽并處理頁面的生命周期函數(shù)、獲取小程序?qū)嵗?,聲明并處理?shù)據(jù),響應(yīng)頁面交互事件等。

//index.js

//獲取應(yīng)用實(shí)例

var app = getApp()

Page({

data: {

motto: ‘Hello World’,

userInfo: {}

},

//事件處理函數(shù)

bindViewTap: function() {

wx.navigateTo({

url: ‘../logs/logs’

})

},

onLoad: function () {

console.log(‘onLoad’)

var that = this

//調(diào)用應(yīng)用實(shí)例的方法獲取全局?jǐn)?shù)據(jù)

app.getUserInfo(function(userInfo){

//更新數(shù)據(jù)

that.setData({

userInfo:userInfo

})

})

}

})

? index.wxss是頁面的樣式表:

/**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;

}

? 頁面的樣式表是非必要的。當(dāng)有頁面樣式表時(shí),頁面的樣式表中的樣式規(guī)則會(huì)層疊覆蓋app.wxss中的樣式規(guī)則。如果不指定頁面的樣式表,也可以在頁面的結(jié)構(gòu)文件中直接使用app.wxss中指定的樣式規(guī)則。

? index.json是頁面的配置文件:

? 頁面的配置文件是非必要的。當(dāng)有頁面的配置文件時(shí),配置項(xiàng)在該頁面會(huì)覆蓋app.json的window中相同的配置項(xiàng)。如果沒有指定的頁面配置文件,則在該頁面直接使用app.json中的默認(rèn)配置。

? logs的頁面結(jié)構(gòu)

<!–logs.wxml–>

<view class=”container log-list”>

<block wx:for-items=”{{logs}}” wx:for-item=”log”>

<text class=”log-item”>{{index + 1}}. {{log}}</text>

</block>

</view>

? logs頁面使用<block/>控制標(biāo)簽來組織代碼,在 <block/>上使用wx:for-items綁定logs數(shù)據(jù),并將logs數(shù)據(jù)循環(huán)展開節(jié)點(diǎn)

//logs.js

var util = require(‘../../utils/util.js’)

Page({

data: {

logs: []

},

onLoad: function () {

this.setData({

logs: (wx.getStorageSync(‘logs’) || []).map(function (log) {

return util.formatTime(new Date(log))

})

})

}

})

運(yùn)行結(jié)果如下:

4. 手機(jī)預(yù)覽

?? 開發(fā)者工具左側(cè)菜單欄選擇”項(xiàng)目”,點(diǎn)擊”預(yù)覽”,掃碼后即可在微信客戶端中體驗(yàn)。

以上就是微信小程序小白教程,希望對(duì)大家有所幫助。如果大家對(duì)微信小程序開發(fā)教程感興趣的,可以看一下。

 

?

微信小程序小白教程最先出現(xiàn)在微信小程序觀察網(wǎng)

]]>
主站蜘蛛池模板: 琼结县| 团风县| 锡林郭勒盟| 沁阳市| 洛隆县| 平遥县| 北流市| 尚义县| 浙江省| 郎溪县| 北流市| 于田县| 微山县| 达州市| 龙岩市| 洪泽县| 宁陕县| 高碑店市| 长兴县| 明水县| 日土县| 井冈山市| 惠安县| 梁山县| 巢湖市| 柯坪县| 定西市| 紫云| 泰宁县| 扎赉特旗| 屯昌县| 铅山县| 昭觉县| 郑州市| 凤山市| 西峡县| 枣强县| 葵青区| 修武县| 南昌县| 河池市|