집 >위챗 애플릿 >미니 프로그램 개발 >미니 프로그램 개발 시 발생하는 문제점 요약
미니 프로그램 면접 질문
1. 바인드탭과 캐치탭의 차이점은 무엇인가요? bind
이벤트 바인딩은 버블링 이벤트가 위쪽으로 버블링되는 것을 방지하지 못합니다. catch이벤트 바인딩은 버블링 이벤트가 위쪽으로 버블링되는 것을 방지할 수 있습니다.2,
Js 배열 변환에 대한 기능은 무엇입니까? 문자열을 변경하고, 정수로 강제 변환하고, 부동 소수점 숫자로 변환합니까? js는 두 가지 변환 함수인parseInt()와parseFloat()를 제공합니다. 전자는 값을 정수로 변환하고 후자는 값을 부동 소수점 숫자로 변환합니다. String 유형에서 이러한 메서드를 호출해야만 이 두 함수가 다른 유형에 대해 올바르게 실행될 수 있으며 NaN(숫자가 아님)이 반환됩니다.
관련 무료 학습 권장사항:
1. 변환 기능:문자열이 숫자 값인지 판단하기 전에,parseInt()와parseFloat()는 둘 다 수행됩니다. 문자열을주의 깊게 분석하십시오. parseInt() 메서드는 먼저 위치 0의 문자를 확인하여 유효한 숫자인지 확인합니다. 그렇지 않은 경우 메서드는 NaN을 반환하고 다른 작업을 계속 수행하지 않습니다. 그러나 문자가 유효한 숫자인 경우 메서드는 위치 1의 문자를 보고 동일한 테스트를 수행합니다. 이 프로세스는 유효한 숫자가 아닌 문자가 발견될 때까지 계속되며, 이때parseInt()는 문자 앞의 문자열을 숫자로 변환합니다.
parseInt("1234blue"); //returns 1234 parseInt("0xA"); //returns 10 parseInt("22.5"); //returns 22 parseInt("blue"); //returns NaN2. 강제 유형 변환
유형 캐스팅을 사용하여 변환된 값의 유형을 처리할 수도 있습니다. 다른 유형이더라도 특정 값에 액세스하려면 캐스트를 사용하십시오.
ECMAScript에서 사용할 수 있는 세 가지 유형의 캐스트는 다음과 같습니다.
Boolean(value) - 주어진 값을 부울 유형으로 변환합니다.
Number(value) - 주어진 값을 숫자로 변환합니다. 정수 또는 부동 소수점 숫자)
String(value) - 주어진 값을 문자열로 변환합니다.
작은 예를 들어보면 한 눈에 이해될 것입니다.
<script> var str= '012.345 '; var x = str-0; x = x*1; </script>위의 예는 js의 약한 유형 특성을 활용하고 산술 연산만 수행하여 문자열에서 숫자로 유형 변환을 수행하지만 이 방법은 여전히 권장되지 않습니다.
3.
WeChat 미니 프로그램 관련 파일 형식을 간략하게 설명하세요. 미니 프로그램: 페이지 ——index: index.js(Page logic
) /index.wxml(페이지 구조)/index.wxss(페이지 스타일 시트) / index.json(페이지 구성) App.js 미니 프로그램 로직
App.json 미니 프로그램 공개 설정
App.wxss 미니 프로그램 공개 스타일 시트
4
미니에서 매개변수를 전달하는 방법은 무엇입니까? 프로그램? 1. 점프 후 매개변수 값을 전달하도록 ID 메소드 식별자를 설정합니다.
2. 전달할 값을 식별하기 위해 데이터 - xxxx 메소드를 사용합니다.WeChat 애플릿은 value
점프하려는 항목에 id를 설정하고 해당 키 값을 영화의 id와 같은 현재 id에 할당합니다(그런 다음 해당 id로 다음 페이지로 이동하여 자세한 정보를 쿼리합니다) ), 예:
나중에 js의 바인딩 탭 응답 이벤트에서 가져와서 다음 인터페이스로 전달합니다.
id가 전달한 값을 가져옵니다
e.currentTarget을 통해 설정된 ID 값을 가져옵니다. .id; 값을 전달하도록 전역 객체 설정
전역 객체 가져오기 var app=getApp() 通过使用data - xxxx 的方法标识来传值 通过使用data - xxxx 的方法标识来传值,xxxx可以自定义取名 比如data-key等等都可以。 如何获取data-xxxx传递的值? 在js的bindtap的响应事件中: 通过数据解析一层层找到数据,var id=e.target.dataset.id(根据你的data-id的取名) 微信小程序如何跨页面获取值? 依据上面的方式设置要传递的值,页面跳转后,我们就需要在下一个页面拿到传递的数据(这个数据在传递前,就已经被设置成全局变量) 在跳转后的js页面,接收传递过来的数据detail.js 同样通过全局额方式取值出来,(即和app.js中取某个变量的值是一样的) var movieid=getApp().MovieDetailid; 5、简述下wx.navigateTo(), wx.redirectTo(), wx.switchTab(), wx.navigateBack(), wx.reLaunch()的区别? 微信小程序 跳转页面 小程序页面有2种跳转,可以在wxml页面或者js中: 1,在wxml页面中: 2,在js页面中: 【注意】此处注意两个关键词 “应用内的页面” 和 “tabBar页面”。 app.json文件中tabBar中注册过的tab页,即为“tabBar页面”,非tabBar中注册占用的页面即为“应用内的页面” 。 如下图:home页面为“应用内的页面”,index和logs页面则为 “tabBar页面”。 3,如果上述跳转遇到跳转失败或无效的问题,请访问下面链接: wx.navigateTo/wx.redirectTo 无效 6、如果需要用户授权,用户选择拒绝授权,此时应该如何处理? 在微信小程序开发时,当我们调用API wx.getUserInfo(OBJECT) 时,需要用户授权。但如果用户拒绝授权,我们如何兼容用户拒绝授权状态,拥有更好的用户体验呢? 先看看这个接口的官方文档: wx.getUserInfo(OBJECT) 获取用户信息,需要先调用 wx.login 接口。 OBJECT参数说明: 参数名 类型 必填 说明 withCredentials Boolean 否 是否带上登录态信息 success Function 否 接口调用成功的回调函数 fail Function 否 接口调用失败的回调函数 complete Function 否 接口调用结束的回调函数(调用成功、失败都会执行) 1. tip: wx.getUserInfo 接口需要用户授权,请兼容用户拒绝授权的场景。 我们就是要在用户点击拒绝的时候,弹出提示框,提示用户以提升用户体验。像下面这样的。 用具体代码实现就是,将弹窗写在 wx.getUserInfo 的fail回调函数中,像下面这样: 这样用户就获得了提示信息,但此时,用户还是停留在页面的,如果某些展示信息,还是给要给用户展示的,只是在进行某些操作的时候要对授权进行验证的话,那就得继续修改我们的代码,保存用户的登录态,在其他地方做验证使用。 第一种思路: 保存登录态这里是这样的,将用户的登录信息传给后台,后台保存用户信息,同时用 open_id 在后台换取一个SessionId 用换取的这个SessionId 存在缓存,做为登录态验证。 这样我们将登录态保存在了 SessionId 中,在每次登录的时候我们只需要再调用一个 检查 SessionId的接口就行,检查不通过再调微信登录接口。此处不做延伸了。 第二种思路: 在3.29微信小程序更新的版本中,加入了这样一条属性 withCredentials 字段基础库版本 1.1.0 开始支持,低版本需做兼容处理 这个字段的意思就是调用 wx.getUserInfo(OBJECT) 是否带上 登录态 的信息。 官方文档是这样解释的: withCredentials 字段基础库版本 1.1.0 开始支持,低版本需做兼容处理 注:当 withCredentials 为 true 时,要求此前有调用过 wx.login 且登录态尚未过期,此时返回的数据会包含 encryptedData, iv 等敏感信息;当 withCredentials 为 false 时,不要求有登录态,返回的数据不包含 encryptedData, iv 等敏感信息。 success返回参数说明: 参数 类型 说明 userInfo OBJECT 用户信息对象,不包含 openid 等敏感信息 rawData String 不包括敏感信息的原始数据字符串,用于计算签名。 signature String 使用 sha1( rawData + sessionkey ) 得到字符串,用于校验用户信息。 encryptedData String 包括敏感数据在内的完整用户信息的加密数据,详细见加密数据解密算法 iv String 加密算法的初始向量,详细见加密数据解密算法 注:需要兼容微信低版本,向后兼容。 那么利用这个接口,我们可以直接拿到 登录状态,在其他需要验证登录的地方进行提示,而在不需要授权的地方还可以让用户浏览小程序。 回到前面的问题,在用户点击拒绝授权后,在某些操作时需要验证用户是否授权过,弹出交互信息,那么就利用上面的 SessionId或者 withCredentials 登录态进行下面的操作: 效果像这样: 这样一个简单完整的登录及授权,登录态保存等前端微信小程序解决方案就完成了,还可以继续扩展到登录有效期,退出登录,用户权限等跟多扩展的地方。 7、你平时封装可以复用的方法吗?你会把可以复用的方法写在哪个文件里? 其实可以模拟一些框架的,比如bootsrap,写个demo出来,抽出css和js,js最好抽象成对象(构造函数)或者是带参数的方法,然后你只要声明对像,或者参数指定某个class或id,就可以了 写在html文件里有什么优点吗? 8、分析下小程序的优劣势? 小程序是在微信生态发展过程中新出现的一种应用形态,小程序的小,从某种程度上已经说明了它的体量不会很大,但是可以实现一些功能相对简单、交互相对简单的服务需求,同时解决了App长期以来多平台适配、多应用市场分发、开发成本居高不下等诸多方面的问题。所以小程序【密件】依靠微信平台和自身“阅后即焚”的功能,获得众多年轻人的好评 优势: 1)容易上手,只要之前有HTML+CSS+JS基础知识,写小程序基本上没有大问题;当然如果了解ES6+CSS3则完全可以编写出即精简又动感的小程序; 2)基本上不需要考虑兼容性问题,只要微信可以正常运行的机器,就可以运行小程序; 3)基本组件库已经比较齐全:Toast,Loading框,Picker,定位及地图,Image,Input,Checkbox,Text,TextArea,ScrollView等常用的组件都有,而且使用也挺简单、方便; 4)发布、审核高效,基本上上午发布审核,下午就审核通过,升级简单,而且支持灰度发布; 5 ) 微信官方提供使用人数、频率等数据统计,小程序js脚本执行错误日志; 6)开发文档比较完善,开发社区比较活跃; 7)最近刚开放的牛x功能,新增webview组件,可以展示网页啦,这个比较爽; 8)支持插件式开发,一些基本功能可以开发成插件,供多个小程序调用; 劣势: 1)后台调试麻烦,因为API接口必须https请求,且公网地址,也就是说后台代码必须发布到远程服务器上;当然我们可以修改host进行dns映射把远程服务器转到本地,或者开启tomcat远程调试;不管怎么说终归调试比较麻烦。 2)前台测试有诸多坑,最头疼莫过于模拟器与真机显示不一致(之前碰到一个案例,后续单独讲解) 3)真机测试,个别功能安卓和苹果表现迥异,我们的小程序里有很多页面有定位功能,模拟器和iphone定位瞬间完成,然而安卓手机就蛋疼了,老显示“定位中...”要很久才能定位好。后来没办法只能优化,减少定位次数。 4)native组件,展示很不好,比如textarea,不能在滚动页面出现,而且至于顶层,经常其它组件会被它遮挡,点击其它组件时,就进入textarea输入框;画布组件也是如此; 5)页面跳转深度不能超过5个页面,这个比较麻烦,有些复杂的页面跳转没法实现,不过太复杂的话也有悖小程序简单易用的原则啦; 6)小程序升级问题,官方文档说会自动更新,实际情况往往是要先把原来的小程序删除掉,重新搜索添加,才能加载最新版本; 7)页面渲染稳定性有待提高,已经好几次出现部分用户的页面显示异常,整个页面被放大了好几倍,先删除原来小程序再添加回来,如此重复好几次,才能显示正常; 8)js引用只能使用绝对路径,很蛋疼;基于安全性及MINA框架实现原理,小程序中对js使用做了很多限制,不能使用:new Function,eval,Generator,不能操作cookie,不能操作DOM; 9)开发工具bug比较多且效率比较低,三天两头升级,解决老问题的同时又出现问题;文件查找、资源定位、代码编辑较eclipse有一定差距。经常出现把a.js当做b.js来修改 9、设置值到页面暂存区(即data)里面的方法有几种?分别是什么?有什么区别? 1. 使用QueryString变量 2. 使用Application 对象变量 3. 使用Session变量 4. 使用Cookie对象变量 5. 使用Server.Transfer方法 微信小程序--data的赋值与取值 通过小程序官方文档可知: Page() 函数用来注册一个页面。接受一个 object 参数,其指定页面的初始数据、生命周期函数、事件处理函数等。其中的参数data用来设置初始数据,WXML 中的动态数据均来自对应 Page 的 data。 所以如果页面需要显示动态数据必须要把数据更新到data中对应的变量中。 页面js文件中这么写: 如果该数据在操作过程中发生变化,需要将新数据重新绑定到该变量中,写法如下: 如果想在js文件中使用data中的数据写法如下: 10、如何检测用户的微信版本是否支持某项功能? 첫 번째 단계에서 열린 인터페이스는 사용할 수 없지만 테스트가 필요하지 않으며 모두 지원됩니다. 11. 서브 패키지 로딩 방법은? 서브패키지 로딩의 장점은 무엇입니까? 하위 패키지 로딩 소개 假设支持分包的小程序目录结构如下: 开发者通过在 app.json subPackages 字段声明项目分包结构:
分包加载的低版本兼容问题 12、在你开发小程序的过程中遇到过什么坑? 你是怎么解决的? 1.我们使用app.json文件来对微信小程序进行全局配置,决定页面文件的路径、窗口表现、设置网络超时时间、设置多 tab 的时候在pages中写注释的时候回报错。 此时就会报错 ②但是在对页面json文件进行配置的时候只可以配置设置默认页面的窗口表现(即只能对window进行配置),但是在此时可以直接省略window,如果加window则没有效果,也不会报错。 注意:这是错误的写法 注意:正确的写法 4.此前一直没有注意vertical-align: middle和height:40rpx;line-height:40rpx进行设置垂直剧中的区别,这次主要说一下vertical-align: middle 总结: 相关学习推荐:小程序开发教程
//전역 요청 액세스에 의해 전달된 매개변수 설정
팁: 실제로 wxml에서 우리가 설정한 각 항목의 id 값을 볼 수도 있습니다
console.log(movieid);<navigator url="../index/index">跳转到新页面</navigator>
<navigator url="../index/index" open-type="redirect">在当前页打开</navigator>
<navigator url="../index/index" open-type="switchTab">切换到首页Tab</navigator>
wx.getUserInfo({
success: function (resuser) {
console.log(success)
},
fail: function () {// 调用微信弹窗接口
wx.showModal({
title: '警告',
content: '您点击了拒绝授权,将无法正常使用******的功能体验。请10分钟后再次点击授权,或者删除小程序重新进入。',
success: function (res) {
if (res.confirm) {
console.log('用户点击确定')
}
}
})
}
})
wx.getUserInfo({
success: function (resuser) {
let userInfo = resuser.userInfo
that.healthApi.login(code, userInfo).then(logindata => { // 这里将微信的请求封装成Promiese 风格
if (logindata.code === 0) {
var sessionId = logindata.data// 调用微信wechat.setStorage将换回来的 SessionId 存在本地缓存
that.wechat.setStorage('sessionId', sessionId).then(() => {
that.globalData.userInfo = userInfo
typeof cb == "function" && cb(that.globalData.userInfo)
})
}
})
},
fail: function () {
wx.showModal({
title: '警告',
content: '您点击了拒绝授权,将无法正常使用*****的功能体验。请10分钟后再次点击授权,或者删除小程序重新进入。',
success: function (res) {
if (res.confirm) {
console.log('用户点击确定')
}
}
})
}
})
applyIn: function applyIn() {
if (wx.getStorageSync('sessionId')) { // 根据储存的sessionId 进行验证
wx.navigateTo({
url: 'familyDoctorApply/familyDoctorApply?Oid=' + this.data.params.Oid + '&title=' + this.data.params.title + '&serviceCity=' + this.data.array[this.data.index].name + '&productPrice=' + this.data.product.productPrice
});
} else {
wx.showModal({
title: '警告',
content: '您点击了拒绝授权,无法使用此功能。',
success: function (res) {
if (res.confirm) {
console.log('用户点击确定')
}
}
})
}
独立出来会有什么问题吗?尤其是载入页面的时候,应该会多发很多http请求吧,会不会造成加载变慢?
QueryString是一种非常简单的传值方式,他可以将传送的值显示在浏览器的地址栏中。如果是传递一个或多个安全性要求不高或是结构简单的数值时,可以使用这个方法。但是对于传递数组或对象的话,就不能用这个方法了。下面是一个例子:
a.aspx的C#代码 private void Button1_Click(object sender, System.EventArgs e)
{
string s_url;
s_url = "b.aspx?name=" + Label1.Text;
Response.Redirect(s_url);
}
b.aspx中C#代码
private void Page_Load(object sender, EventArgs e)
{
Label2.Text = Request.QueryString["name"];
}
Application对象的作用范围是整个全局,也就是说对所有用户都有效。其常用的方法用Lock和UnLock。
a.aspx的C#代码 private void Button1_Click(object sender, System.EventArgs e)
{
Application["name"] = Label1.Text;
Server.Transfer("b.aspx");
}
b.aspx中C#代码
private void Page_Load(object sender, EventArgs e)
{
string name;
Application.Lock();
name = Application["name"].ToString();
Application.UnLock();
}
想必这个肯定是大家使用中最常见的用法了,其操作与Application类似,作用于用户个人,所以,过量的存储会导致服务器内存资源的耗尽。
a.aspx的C#代码 private void Button1_Click(object sender, System.EventArgs e)
{
Session["name"] = Label.Text;
}
b.aspx中C#代码
private void Page_Load(object sender, EventArgs e)
{
string name;
name = Session["name"].ToString();
}
这个也是大家常使用的方法,与Session一样,其是什对每一个用户而言的,但是有个本质的区别,即Cookie是存放在客户端的,而session是存放在服务器端的。而且Cookie的使用要配合ASP.NET内置对象Request来使用。
a.aspx的C#代码 private void Button1_Click(object sender, System.EventArgs e)
{
HttpCookie cookie_name = new HttpCookie("name");
cookie_name.Value = Label1.Text;
Reponse.AppendCookie(cookie_name);
Server.Transfer("b.aspx");
}
b.aspx中C#代码
private void Page_Load(object sender, EventArgs e)
{
string name;
name = Request.Cookie["name"].Value.ToString();
}
这个才可以说是面象对象开发所使用的方法,其使用Server.Transfer方法把流程从当前页面引导到另一个页面中,新的页面使用前一个页面的应答流,所以这个方法是完全面象对象的,简洁有效。
a.aspx的C#代码 public string Name
{
get{ return Label1.Text;}
}
private void Button1_Click(object sender, System.EventArgs e)
{
Server.Transfer("b.aspx");
}
b.aspx中C#代码
private void Page_Load(object sender, EventArgs e)
{
a newWeb; //实例a窗体
newWeb = (source)Context.Handler;
string name;
name = newWeb.Name;
}
Page({
data: {
message: 'Hello MINA!'
}
})
· wxml中这么写:
<view> {{ message }} </view>
function setData(){
var that = this;
that.setData({
message: '新消息'
})
}
function getData(){
var that = this;
console.log(that.data.message)
}
최신 개방형 인터페이스만 지원 여부를 확인하면 됩니다.
현재 열려 있는 모든 인터페이스:
onMenuShareTimeline
onMenuShareAppMessage
onMenuShareQQ
onMenuShareWeibo
onMenuShareQZone
startRecord
stopRecord
onVoiceRecordEnd
playVoice
pauseVoice
stopVoice
onVoicePlayEnd
uploadVoice
downloadVoice
chooseImage
previewImage
uploadImage
downloadImage
translateVoice
getNetworkType
openLocation
getLocation
hideOptionMenu
showOptionMenu
hideMenuItems
showMenuItems
hideAllNonBaseMenuItem
showAllNonBaseMenuItem
closeWindow
s canQRCode
chooseWXPay
openProductSpecificView
addCard
chooseCard
openCard
대부분의 작은 프로그램은 특정 기능으로 구성됩니다. 일반적으로 이러한 기능은 서로 독립적이지만 일부 공통 논리에 의존하며 이러한 기능은 일반적으로 여러 기능에 해당합니다. 독립 페이지. 그러면 미니 프로그램 코드의 패키지를 하나의 패키지로 묶을 필요가 없으며, 특정 기능이 필요한 경우에는 이 기능에 해당하는 하위 패키지를 여러 개로 나눌 수 있습니다. 짐을 실은.
사용자의 경우 미니 프로그램 로딩 과정은 다음과 같습니다.
1. 처음 시작할 때 미니 프로그램의 메인 패키지를 다운로드하고 메인 패키지의 페이지를 표시합니다. 사용자가 특정 하위 패키지 페이지에 들어간 후 해당 하위 패키지를 다운로드하면 다운로드가 완료되고 하청 계약 페이지가 표시됩니다.
개발자는 하위 패키징 로딩을 사용하여 미니 프로그램의 코드 용량을 늘리고 사용자를 위해 더 많은 기능과 서비스를 제공할 수 있으며 시작에 영향을 주지 않으면서 미니 프로그램을 더 빠르게 열 수 있습니다. 속도.
하위 계약 분할
구성하기 전에 개발자는 먼저 각 하위 계약이 수용해야 하는 콘텐츠를 계획해야 합니다. 기능 분할 원칙에 따라 페이지와 로직을 동일하게 배치하는 것이 좋습니다. function 동일한 디렉터리에서 교차 기능 간의 일부 공통 논리를 기본 패키지 아래에 배치합니다. 이렇게 하면 하위 패키징이 함수의 이 부분을 참조할 때 논리의 이 부분이 존재해야 합니다.
하도급 분할 시에는 다음 사항에 주의해야 합니다.
1. 하도급 간 참조 중복을 피하세요. 하위 패키지의 로딩은 사용자 작업에 의해 실행되므로 특정 하위 패키지가 로드될 때 반드시 다른 하위 패키지가 존재할 것이라는 보장은 없습니다. 이로 인해 ""xxx.js가 보고되는 등 JS 로직 이상이 발생할 수 있습니다. " 정의되지 않았습니다";
2. 공용 사용을 위한 일부 사용자 정의 구성 요소는 기본 패키지에 배치되어야 합니다.
하도급 구성
하도급 구분을 명확히 한 후 하도급을 구성하면 됩니다.
微信 6.6.0 版本开始支持分包加载,而对于低于这个版本的客户端,我们做了兼容处理,开发者不需要对老版本微信客户端做兼容。对于老版本的客户端,编译后台会将所有的分包打包成一个整包,老版本的客户端依然按照整包的方式进行加载。
所以在老版本的微信客户端下,是依然采取整包加载的方式加载的,建议开发者尽量控制代码包的大小。
目前小程序分包大小的限制:
整个小程序所有分包大小不超过 4M
单个分包/主包大小不能超过 2M
随着时间推移,老版本覆盖率降低,我们会考虑进一步扩大代码包的大小。
例如:{
"pages":[
//这是首页面
"pages/welcome/welcome"
]}
2.在json文件中没有写内容的时候也要加一对大括号{ },不然的话也会报错
3. ①在开发微信小程序的时候,我们使用app.json文件来对微信小程序进行全局配置,决定页面文件的路径,窗口表现,设置网络超时时间,设置多Tab等。
以下是一个包含了所有配置选项的简单配置,app.json :{
//设置页面路径
"pages": [
"pages/index/index",
"pages/logs/index"
],
//设置默认页面的窗口表现
"window": {
"navigationBarTitleText": "Demo"
},
//设置底部 tab 的表现
"tabBar": {
"list": [{
"pagePath": "pages/index/index",
"text": "首页"
}, {
"pagePath": "pages/logs/logs",
"text": "日志"
}]
},
//设置网络超时时间
"networkTimeout": {
"request": 10000,
"downloadFile": 10000
},
//设置是否开启 debug 模式
"debug": true
}
以下是一个包含了window配置选项的简单配置,post.json :{
"window":{
"navigationBarBackgroundColor": "#ffffff",
"navigationBarTextStyle": "black",
"navigationBarTitleText": "微信接口功能演示",
"backgroundColor": "#eeeeee",
"backgroundTextStyle": "light"
}}
{
"navigationBarBackgroundColor": "#ffffff",
"navigationBarTextStyle": "black",
"navigationBarTitleText": "微信接口功能演示",
"backgroundColor": "#eeeeee",
"backgroundTextStyle": "light"}
代码如下:<view class="post-author-date">
<image class="post-author" src="../../images/avatar/1.png">
</image>
<text class="post-date">Nov 15 2016</text>
</view>
.post-author{
width: 60rpx;
height: 60rpx;
vertical-align: middle;
}
.post-date{
margin-top: 5rpx;
vertical-align: middle;
/*height: 40rpx;
line-height: 40rpx;*/
}
①vertical-align: middle;把此元素放在父元素的中部
②当一个父元素里面有多个子元素,需要把几个子元素水平对齐,并且每个子元素都垂直剧中的时候,对每一个子元素进行设置 vertical-align: middle
③height: 40rpx; line-height: 40rpx;可以对文本进行垂直居中
위 내용은 미니 프로그램 개발 시 발생하는 문제점 요약의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!