微信开发者工具报错map

2017-01-04 14:17:20 u010635353 阅读数 50587

功能点:页面跳转
本文基于微信小程序公测版,IDE:微信开发者工具 0.11.122100

这里记录一下小程序中页面跳转的方式。

从跳转的方式(或说成打开新页面的方式)来说大致可分为:请求转发请求重定向TAB页跳转(有过web经验的话,应该很清楚两种方式的区别),部分出自官方文档。

wx.navigateTo(OBJECT)

保留当前页面,跳转到应用内的某个页面,使用wx.navigateBack可以返回到原页面。

这里写图片描述

注意点:小程序中要求页面的层级最多只能有五层,因为这种方式保留当前页面,也就是说以这种方式跳转页面,最多只能打开5个页面。


wx.redirectTo(OBJECT)

关闭当前页面,跳转到应用内的某个页面。

这里写图片描述


wx.switchTab(OBJECT)

跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面

这里写图片描述


wx.navigateBack(OBJECT)

关闭当前页面,返回上一页面或多级页面。可通过 getCurrentPages()) 获取当前的页面栈,决定需要返回几层。

这里写图片描述

注意点:
1.这里需要强调一下小程序中以堆栈形式记录页面。每一个以wx.navigateTo(OBJECT) 方式跳转的页面都会被压入堆栈,但是以wx.redirectTo(OBJECT) 打开的页面则不会。借用一下官方的例子,很清晰明了。

// 此处是A页面
wx.navigateTo({
  url: 'B?id=1'
})

// 此处是B页面
wx.redirectTo({
  url: 'C?id=1'
})

// 在C页面内 navigateBack,将返回A页面
wx.navigateBack()

**2.**wx.navigateTo 和 wx.redirectTo 不允许跳转到 tabbar 页面,只能用 wx.switchTab 跳转到 tabbar 页面

3. 跳转的url是页面的路径(非Tab页面),如需传递参数,要放在路径之后,以 分隔,参数键与参数值用=相连,不同参数用&分隔


从写的位置来说大致可分为两种,一种是在页面wxml文件中以标签的形式,另一种是代码的形式(这种上面已经列举出来了,此处不再赘述)。

组件navigator

页面链接。

这里写图片描述

通过open-type 可以指定跳转的方式是请求转发,请求重定向还是TAB页跳转。(效果同上面js代码的效果,此处不再赘述)


这里记录一个笔者遇到的坑,坑了我一晚上。。。也是很无语。虽然不是页面跳转的问题,但是也有一定联系,姑且记在这里。

本来我的项目首页有两个tab,需要在其中一个列表页中点击一个item进入详情,查看地图。然而,不管我怎么尝试,文档撸了N遍,都还是没解决。

先贴出异常

这里写图片描述

上面报错的aboutUs是首页的其中另一个tab,只是一个展示页,没有操作,所以虽然报错了,然而我并没有管。问题出在我跳转pages/map(详情的地图)的时候,提示我如上最后一行的错误。

Page[pages/map/map] not found. May be caused by: 1. Forgot to add page route in app.json. 2. Invoking Page() in async task.

按照笔者以前android和后台的经验,一直把问题定位到map页的本身。撸了N久都没解决。后来心血来潮把aboutUs的异常解决了,发现问题奇迹般的解决了。

问题出在,aboutUs页,因为只是一个静态页,并没有操作,所以aboutUs.js是空的,问题就出在这。

在小程序中,即时不需要写js的代码,那js文件中也必须要加上Page({})

2017-01-29 12:20:00 u011495204 阅读数 67729

环境搭建

  • 注册,获取APPID(没有这个不能真鸡调试)
  • 下载微信web开发者工具(挺多bug,将就用)
  • 打开微信web开发者工具,扫码登录,新建小程序,输入APPID,勾选创建quick start项目。

工程结构

可以看到工程根目录中有个app.js,这里可以定义全局变量,通过getApp()获取。
项目中有了一些示例,已经有了获取用户信息的方法等。

开发地图定位,选择位置功能

我们直接修改index页面来做这个功能。

准备

  • 新建imgs目录,加入2个图标(ic_location和ic_position),用于标记当前位置,和地图中央位置。
  • ic_location
  • ic_position

添加定位功能

修改app.js,加入定位功能,获取当前位置。

//app.js
App({
  onLaunch: function () {
    //调用API从本地缓存中获取数据
    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{
      //调用登录接口
      wx.login({
        success: function () {
          wx.getUserInfo({
            success: function (res) {
              that.globalData.userInfo = res.userInfo
              typeof cb == "function" && cb(that.globalData.userInfo)
            }
          })
        }
      })
    }
  }
  //get locationInfo
  ,getLocationInfo: function(cb){
    var that = this;
    if(this.globalData.locationInfo){
        cb(this.globalData.locationInfo)
    }else{
        wx.getLocation({
          type: 'gcj02', // 默认为 wgs84 返回 gps 坐标,gcj02 返回可用于 wx.openLocation 的坐标
          success: function(res){
            that.globalData.locationInfo = res;
            cb(that.globalData.locationInfo)
          },
          fail: function() {
            // fail
          },
          complete: function() {
            // complete
          }
        })
    }
  }

  ,globalData:{
    userInfo:null
    ,locationInfo: null
  }
})

地图控件布局

修改pages/index/index.wxml文件,添加map标签,如下


<map id="map4select"
 longitude="{{longitude}}" latitude="{{latitude}}" 
 markers="{{markers}}"
 scale="20" 
 style="width:{{map_width}}px;height:{{map_height}}px"
 bindregionchange="regionchange"
 controls="{{controls}}">
</map>
  • 需要给地图指定一个id,后面可以通过id获取地图的上下文。
  • 监听bindregionchange事件,地图变化的时候可以监听到。
  • 地图的大小不要写死,动态设置,我这里打算设置为宽高都是屏幕宽度。
  • controls是固定在map组件上面的。一开始我想用image替代,但是设置z-index也不能在地图上面,毕竟不是H5开发。

逻辑代码编写

编辑index.js

var app = getApp()

Page({
    data:{
      map_width: 380
      ,map_height: 380
    }
    //show current position
    ,onLoad: function(){
    var that = this;
    // 获取定位,并把位置标示出来
    app.getLocationInfo(function(locationInfo){
        console.log('map',locationInfo);
        that.setData({
          longitude: locationInfo.longitude
          ,latitude: locationInfo.latitude
          ,markers:[
            {
            id: 0
            ,iconPath: "../../imgs/ic_position.png"
            ,longitude: locationInfo.longitude
            ,latitude: locationInfo.latitude
            ,width: 30
            ,height: 30
            }
          ]
        })
    })

    //set the width and height
    // 动态设置map的宽和高
    wx.getSystemInfo({
      success: function(res) {
        console.log('getSystemInfo');
        console.log(res.windowWidth);
        that.setData({
           map_width: res.windowWidth
          ,map_height: res.windowWidth
          ,controls: [{
            id: 1,
            iconPath: '../../imgs/ic_location.png',
            position: {
              left: res.windowWidth/2 - 8,
              top: res.windowWidth/2 - 16,
              width: 30,
              height: 30
            },
            clickable: true
          }]
        })
      }
    })

  }
  //获取中间点的经纬度,并mark出来
  ,getLngLat: function(){
      var that = this;
      this.mapCtx = wx.createMapContext("map4select");
      this.mapCtx.getCenterLocation({
        success: function(res){

            that.setData({
            longitude: res.longitude
            ,latitude: res.latitude
            ,markers:[
              {
              id: 0
              ,iconPath: "../../imgs/ic_position.png"
              ,longitude: res.longitude
              ,latitude: res.latitude
              ,width: 30
              ,height: 30
              }
            ]
          })

        }
      })
  }
  ,regionchange(e) {
    // 地图发生变化的时候,获取中间点,也就是用户选择的位置
      if(e.type == 'end'){
          this.getLngLat()
      }
  }
  ,markertap(e) {
    console.log(e)
  }
})

展示

这样,就OK啦,用户可以看到自己的定位,如果觉得有偏差,可以移动地图,把中央点放到自己认为的准确位置上。
这里写图片描述
这里写图片描述
这里写图片描述

2020-04-25 09:13:03 u013513053 阅读数 232

最近使用微信开发者工具编译小程序,提示我不升级不能用真机调试,ok我就升级呗,还能咋办。于是乎我就升级
升级之后,发现还是用不了,报出一个异常

Error: ENOENT: no such file or directory, stat 'C:\Users\admin\node_modules\babel-code-frame'  

百度半天也查不出个所以然,大都是说npm的事情,然后我也尝试着使用npm构建一下,但最终还是没有解决问题。
最后,我直接找到C盘目录下的这个路径,想要点开这个文件夹看看到底是什么,但是我也打不开,提示磁盘位置不存在。
我心一横,既然不存在,我就删了罢了。
然后重启工具,报另一个不存在,还是在一个文件夹下,然后接着删掉。
最后运行就正常了

呃呃呃 ,什么原因不知道,但是删掉了就可以了,跟npm没有半毛钱关系

2018-05-16 15:06:01 qq_15576765 阅读数 13794

一般提到:

                     thirdScriptError 

                     sdk uncaught third Error

请检查微信开发者工具右边‘详情’,把ES6转ES5的打勾去掉


2019-04-01 17:10:21 weixin_38937467 阅读数 4933

出现问题情况

关于微信web开发者工具模拟器出现空白问题,代码没错误,在模拟器中无法显示UI界面。

有博主总结点击开发者工具的 “>>”–>详情–>上传代码时自动压缩混淆功能取消勾选。

经过我的调试,取消勾选后也无法看到界面。

在这里插入图片描述


																							.
																							.
																							.

解决方法

我安装的版本是开发版 Nightly Build开发版的简介是日常构建版本,用于尽快修复缺陷和敏捷上线小的特性;开发自测验证,稳定性欠佳。


所以我重新安装了稳定版 Stable Build (1.02.1902010),成功解决了模拟器出现空白问题,建议大家安装稳定版本。

以下是map组件成功运行在模拟器的界面。

在这里插入图片描述