为何在mui.ajax 浏览器跨域中无法正常使用mui,一定要在手机里调试吗

javascript/jquery/es6(3)
手机端网页的调试
致谢:这个使用的工具来自eruda,在此感谢我的舍友超哥告诉我这个强大的工具
gtihub地址:
近期遇到的问题是电脑端的select指定size,在电脑端正常使用,在手机端不支持size属性,所以想着在手机端添加调试工具,主要目的是打印日志信息,看js的执行结果
问题详情如下链接,在电脑端网页和手机端网页显示完全不一致(size属性导致)
这就是为啥我需要一个手机端调试工具,因为谷歌浏览器的手机模式调试后某些属性也不一定在手机浏览器上支持
在本人的github上面做了一些测试select的页面,最终改成自定义伪select
最终实现的功能:
在手机控制台输出你的log
在手机上运行你的网页
通过日志的打印确保你当前页面不是来自缓存的
直接审查你的网页源码校验是否存在问题
直接显示当前js是否存在错误
还有一些eruda的用途目前不太了解,支持console执行代码,但是目前总是报错,在研究中,使用成功后将能直接在手机端执行输入的js脚本
最终的实现效果如图:
在页面中点击虚拟键即可进入调试页面查看日志信息。
如何在你的手机上看到效果?
安装git,并且安装上gitbash,允许桌面鼠标右键出现gitbash选项,如已配好则无需再配置,克隆git项目
,该项目是多场景的集合,对于select的测试放在了customselect下面。
安装nodejs,安装成功后cmd,在控制台输入node,若没提示错误则安装成功,
搭建nodejs服务器环境,目的是为了能在手机端打开页面,idea的默认63342端口在手机上是打不开的,必须把项目放在类似tomcat的容器里面,所以在这里我选择nodejs,
打开sanVariousProject 项目,将项目下面的http.js和mine.js两个文件复制到sanVariousProject 的上一级目录,
把http.js里面的配置项目名称改为sanVariousProject (当前项目已经配置好可以直接跳过第五步,两个nodejs脚本适用于其他项目)
在sanVariousProject 的上级目录右键打开gitbash,或者在控制台进入sanVariousProject 的上级目录,允许node http.js。端口3000默认启动成功
在浏览器输入(192.168.3.115是你自己的ip地址,查看自己ip地址方式:进入cmd 接着输入ipconfig即可看到)
如果浏览器页面打不开,那么说明的你防火墙把它限制了,这时关闭防火墙(win+R进入允许端口,输入control进入控制面板,接着搜索防火墙,进入防火墙后上下两处均选择关闭防火墙。)
直到输入(用你的ip替换192.168.3.115)成功显示页面
电脑浏览器成功显示后即可直接在手机端浏览器打开链接,开始你的手机页面调试。
正在研究eruda是否支持手机端输入脚本能excute成功,能直接运行输入脚本将极大提高效率
参考知识库
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:6679次
排名:千里之外
原创:15篇
(1)(3)(2)(3)(1)(4)(1)mui适用场景说明,能不能在普通浏览器里使用,能否用于wap网站_百度知道26947人阅读
04_JS&JQ&UI(37)
使用hbuilder+mui做app一段时间,期间遇到问题不少,
自己摸索,做了个app,详见:
如果您水平比这个高,那就不用看了,直接跳过。
由于用hbuilder+mui出于兴趣,也就没有去看源码,
停留在使用总结层次,所以有说的不对的地方还请见谅。
【几种打开页面的方式】
1.初始化时创建子页面
2.直接打开新页面
3.预加载页面
1.初始化时创建子页面
mui.init({
subpages: [{
url: your - subpage - url, //子页面HTML地址,支持本地地址和网络地址
id: your - subpage - id, //子页面标志
top: subpage - top - position, //子页面顶部位置
bottom: subpage - bottom - position, //子页面底部位置
width: subpage - width, //子页面宽度,默认为100%
height: subpage - height, //子页面高度,默认为100%
extras: {} //额外扩展参数
2.直接打开新页面
mui.openWindow({
url: new - page - url,
id: new - page - id,
top: newpage - top - position, //新页面顶部位置
bottom: newage - bottom - position, //新页面底部位置
width: newpage - width, //新页面宽度,默认为100%
height: newpage - height, //新页面高度,默认为100%
..... //自定义扩展参数,可以用来处理页面间传值
autoShow: true, //页面loaded事件发生后自动显示,默认为true
aniShow: animationType, //页面显示动画,默认为”slide-in-right“;
duration: animationTime //页面动画持续时间,Android平台默认100毫秒,iOS平台默认200毫秒;
waiting: {
autoShow: true, //自动显示等待框,默认为true
title: '正在加载...', //等待对话框上显示的提示内容
options: {
width: waiting - dialog - widht, //等待框背景区域宽度,默认根据内容自动计算合适宽度
height: waiting - dialog - height, //等待框背景区域高度,默认根据内容自动计算合适高度
3.预加载页面
mui.init({
preloadPages: [{
url: prelaod - page - url,
id: preload - page - id,
styles: {}, //窗口参数
extras: {}, //自定义扩展参数
subpages: [{}, {}] //预加载页面的子页面
var page = mui.preload({
url: new - page - url,
id: new - page - id, //默认使用当前页面的url作为id
styles: {}, //窗口参数
extras: {} //自定义扩展参数
【一些区别】
1.子页面和非子页面
以上三种方式中,2,3打开的页面非子页面,
区别是子页面相当于html中的iframe,而非子页面相当于新开了一个浏览器窗口加载了一个html
2.子页面适用于侧滑菜单
子页面有其有点,特别适用与index.html+list.html这种情况,
如果用index.html(主页面)+list.html(子页面)实现的话,当主页面右滑时子页面会自动跟随,
而用index.html(主页面)+list.html(新页面)实现的话,主页面右滑,新页面不右滑,还得单独处理新页面。
3.子页面实用频繁切换的情况
如果频繁左滑右滑,在配置较低的手机上会出现list.html遮住index.html的情况,
采用子页面模式就不会,采用新页面模式几率很大。
4.子页面适用与下拉刷新和上拉加载
之前做大下拉刷新的时候,采用的是新页面的形式,
按照官网教程,怎么搞都不成功,
后来看了下源码,发现下拉刷新必须采用子页面的形式,
也就是你的list.html必须是index.html的子页面,才可以下拉刷新。
5.新页面适用于新页面
open一个新页面,适用于查看详情之类的,需要打开一个新页面的情况,
并且mui自己封装了新页面的back方法,你就不需要去操心了。
6.预加载页面的两种方式
第一种是在初始化的时候预加载,
这种情况适合在你这个页面在很久之后才会用,
如果你要立即到的页面并使用,那么你会得到null。
第二种方式类似与open,
个人感觉没有什么太大的区别,
唯一的区别是open就直接打开了,
preload只是加载,你可以之后选择打开的时机。
需要下拉刷新上拉加载请使用子页面,
需要打开一个新页面请使用新页面方式,
需要加载一个页面但是暂时不使用请使用预加载方式。
参考知识库
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:816365次
积分:7345
积分:7345
排名:第2063名
原创:200篇
转载:14篇
评论:277条

我要回帖

更多关于 mui 调试 的文章

 

随机推荐