翊枫
撸码才能成长,学会深究,懂得填坑

序言:前段时间因公司需要所以就搞了一下小程序,没想到自己遇到的问题还挺多的,不过网上大多有答案,或者api里面有的,今天只是做一个简单记录而已

小程序-背景图的使用

在大部分的页面布局上,我们通常会使用背景图的css变现来渲染页面,小程序的背景图跟我们平时开发有一定的差别

<view class='nav_main' style="background-image: url('../../../img/inte_red.png');"></view>
.nav_main{//如果你的背景图路径是相对路径,那么背景图属性一定要写在标签里。如果是绝对路径,则可以忽略这一点,建议使用绝对路径。
  margin: 0 auto;
  margin-top:15%;
  width: 80%;
  height: 300rpx;
  background-repeat: no-repeat;
  background-size: 100%;
  position: relative;
}

小程序-隐藏scroll-view的滚动条

如果要隐藏scroll-view的滚动条,需要设置css样式:::-webkit-scrollbar

::-webkit-scrollbar {
    width: 0;
    height: 0;
    color: transparent;
}

小程序-页面跳转的问题

  我前面遇到一个问题就是wx.navigateTo无法打开tabBar页面。

  解决方案也很简单

  Tips:

  • navigateToredirectTo 只能打开非 tabBar 页面。
  • switchTab 只能打开 tabBar 页面。
  • reLaunch 可以打开任意页面,但是不建议经常用这个。
  • 页面底部的 tabBar 由页面决定,即只要是定义为 tabBar 的页面,底部都有 tabBar。
  • 调用页面路由带的参数可以在目标页面的onLoad中获取。简单就是从另一个页面进来的,可以新打开页面的生命周期onload:function(option){ let id=option.id;//可以得到路由带的参数id的值 }

小程序-两个for循环嵌套的问题

问题:要在里层for获取最外层的一些数据

<view wx:for="{{[1, 2, 3, 4, 5, 6, 7, 8, 9]}}" wx:for-item="i" wx:key="">
  <view wx:for="{{[1, 2, 3, 4, 5, 6, 7, 8, 9]}}" wx:for-item="j" wx:key="">
    <view wx:if="{{i <= j}}">
      {{i}} * {{j}} = {{i * j}}
    </view>
  </view>
</view>
ps:其实这个很简单,就是我个人钻进牛角尖,大家肯定不会啦,只是记录下自己犯下的傻。其实就是自定义一下wx:for里的item值 这样:wx:for-item="i",不自定义就会跟内层item冲突,所以获取不到外层数据。

小程序-使用三元表达式的一些问题

问题:要对某个数据做一个判断,并且保留两位小数点,就想直接在wxml里对数据进行一些操作,比如

<view wx:for="arr">
    {{lat>1000:(lat/1000).toFixed(2):lat.toFixed(2)}}
</view>

这样是不行的,谨记,多重三元表达式  解析也是有问题 ,要操作的话最好,在js文件里实现。

小程序-点击进行下拉加动效

对当前的元素设定固定的高度。

小程序-使用腾讯地图api

提示域名不合法,解决如下

小程序使用示例

// 引入SDK核心类
var QQMapWX = require('../../libs/qqmap-wx-jssdk.js');
var qqmapsdk;
Page({
 
    onLoad: function () {
        // 实例化API核心类
        qqmapsdk = new QQMapWX({
            key: '申请的key'
        });
    },
    onShow: function () {
        // 调用接口
        qqmapsdk.search({
            keyword: '酒店',
            success: function (res) {
                console.log(res);
            },
            fail: function (res) {
                console.log(res);
            },
        complete: function (res) {
            console.log(res);
        }
    });
 
 
})

 主要说配置安全域名,大家可能不熟悉,步骤:进入小程序后台——设置——开发设置——服务器域名——然后把https://apis.map.qq.com配置进  request 合法域名  就可以了。,网上找资料一堆什么后台接口啥的完全看不懂,还是看了官方文档然后去配就行了,没那么复杂

小程序-动态获取节点高度(wx.createSelectorQuery())

问题:有些就是需要展开收起,但是它高度根据内容渲染出来决定,估计很多人没用过这个,所以就记录一下

首先给你的wxml对象一个id:

<view class="test-box" style="height:66px;" id='box'/>

然后在js里,用一个SelectorQuery来选择对应id的节点(注意id前面要加一个#号),就可以获取对应节点的属性,包括高度。ps:等渲染完成在onShow里获取这个元素高度

//创建节点选择器
var query = wx.createSelectorQuery();
query.select('#box').boundingClientRect()
query.exec(function (res) {
    //res就是 所有标签为box的元素的信息 的数组
    console.log(res);  
    //取高度
    console.log(res[0].height);
})

小程序-使用canvas的一些问题

问题:要在同一个页面实现两个canvas的切换,还有刚开始使用canvas的一些适配问题,canvas使用的是px,要适配所有手机的话,要怎么做呢

废话不多讲,我的一种解决方案

var res = wx.getSystemInfoSync()
console.log(res.windowWidth);

获取手机当前的宽高,然后根据设计图的尺寸进行相对应的比例。这就是一种解决方案,可能还有其他的,欢迎留言告诉我,十分感谢。

嗯,然后就到了canvas的切换问题,大家可能会说,这么简单,有啥难的,直接套一个scroll-view标签就搞定了,emmmmmmmm,其实当时我也是这么想,然后就gg了

在模拟器上开发都没啥问题,但是到了手机上,你会发觉根本无法切换。

然后特意去查了文档,意思是这样的

解决方案

其实解决方案也很简单,想法也很多,最后确定用动画去实现

首先用到wx.createAnimation(OBJECT),这里就要去查一下小程序动画的api animation

页面两个canvas就通过数据控制显示隐藏,在显示隐藏加上动画,看起来就跟切换效果差不多了。

对了,这里就不贴代码了,如果没有尝试过的,可以尝试去实现一下,玩玩。

如果你有更好的方案,欢迎留言告诉我,感谢十分。

 

可能还有其他的,我也忘记了一部分问题。。。等我记得的话会给大家加上。

最后,这里有 一个没啥人的web交流群,也非常欢迎大家加入,qq群:557529704

posted on 2018-05-30 18:28  翊枫  阅读(711)  评论(0编辑  收藏  举报

Stick to the code and become the code God.