细说移动前端Android联调
为什么要联调
A:正在疯狂coding的时候,产品MM过来,焦急的说两周前的一个页面在手机上显示略微错位,但小本上显示正常!
B:本着爱折腾的原则,作为大前端,在移动互联网时代的基本技能。
A:正在疯狂coding的时候,产品MM过来,焦急的说两周前的一个页面在手机上显示略微错位,但小本上显示正常!
B:本着爱折腾的原则,作为大前端,在移动互联网时代的基本技能。
联调的方式:
方式一:ADB Chrome extension:具体参考:这里
步骤一:ADB extension
步骤二:安装手机驱动
步骤三:手机chrome 开发者工具->启动USB网页调试
步骤四:ADB->View Inspection Targets
细节:手机驱动如果不好找就装个91或者豌豆荚吧
优缺点:配置简单,可快速开始。但ADB会闹脾气,时快时慢
优化:解决慢可以尝试用android的sdk本地搞个服务器。
基本配置->下载ADT->CMD(adb forward tcp:8888 localadstract:chromedevtoolsremote)->localhost:8888
步骤一:ADB extension
步骤二:安装手机驱动
步骤三:手机chrome 开发者工具->启动USB网页调试
步骤四:ADB->View Inspection Targets
细节:手机驱动如果不好找就装个91或者豌豆荚吧
优缺点:配置简单,可快速开始。但ADB会闹脾气,时快时慢
优化:解决慢可以尝试用android的sdk本地搞个服务器。
基本配置->下载ADT->CMD(adb forward tcp:8888 localadstract:chromedevtoolsremote)->localhost:8888
方式二:Opera Mobile
步骤一:下载Opera桌面版(低版本) 下载Opera 模拟器
步骤二:打开桌面版的Dragonfly 点击右上角的远程调试设置端口
步骤三:在模拟器中输入 opera:debug 设置端口连接。
细节:Opera桌面版高版本的调试器居然不是dragongly,下低版本(10.52)。
优缺点:简单方便,支持模拟各种机型的显示效果。但是不能选择元素方式不友好。
步骤一:下载Opera桌面版(低版本) 下载Opera 模拟器
步骤二:打开桌面版的Dragonfly 点击右上角的远程调试设置端口
步骤三:在模拟器中输入 opera:debug 设置端口连接。
细节:Opera桌面版高版本的调试器居然不是dragongly,下低版本(10.52)。
优缺点:简单方便,支持模拟各种机型的显示效果。但是不能选择元素方式不友好。
方式三:weinre(web in remote)
步骤一:安装Node.js. => 安装weinre(npm install -g weinre)
步骤二:启动服务器 weinre –httpPort 8080 –boundHost -all-
步骤三:在目标调试文件中加入:
<script src="http://本机ip:8080/target/target-script-min.js#anonymous"></script>
步骤四:localhost:8080/client 即可调试
细节:引入的script标签中必须有#anonymous,否则看不到可调试文件。
优缺点:高端上流,操作简单,可用浏览器自带的调试器调试,适合爱好不同开发者。
缺点是,方便前端开发。
优化:每次都手动引入js很不爽,效率极低。做成书签形式,每次在当前页面引入js。
javascript:(function(e){
e.setAttribute("src","http://192.168.1.5:8080/target/target-script-min.js#anonymous");
document.getElementsByTagName("body")[0].appendChild(e);
alert('has executed!');
})(document.createElement("script"));
void(0);
步骤一:安装Node.js. => 安装weinre(npm install -g weinre)
步骤二:启动服务器 weinre –httpPort 8080 –boundHost -all-
步骤三:在目标调试文件中加入:
<script src="http://本机ip:8080/target/target-script-min.js#anonymous"></script>
步骤四:localhost:8080/client 即可调试
细节:引入的script标签中必须有#anonymous,否则看不到可调试文件。
优缺点:高端上流,操作简单,可用浏览器自带的调试器调试,适合爱好不同开发者。
缺点是,方便前端开发。
优化:每次都手动引入js很不爽,效率极低。做成书签形式,每次在当前页面引入js。
javascript:(function(e){
e.setAttribute("src","http://192.168.1.5:8080/target/target-script-min.js#anonymous");
document.getElementsByTagName("body")[0].appendChild(e);
alert('has executed!');
})(document.createElement("script"));
void(0);
结语:
移动端调试虽好玩,但是太折腾,保证效率,只能作为最后法宝
遇到问题:Bug现象->本地调试->定位bug->确定是否联调
细说移动前端Android联调的更多相关文章
- 【Java分享客栈】我有一个朋友,和前端工程师联调接口被狠狠鄙视了一番。
前言 我有一个朋友,昨天和前端工程师联调一个接口,然后被狠狠鄙视了一番. 大家知道,自从前后端分离以后,像我一样一直以Java工程师为傲而自居的码圣们就砍掉了一半脊梁,从此被贴上了"Java ...
- 后端Spring Boot+前端Android交互+MySQL增删查改
2021.1.27 更新 已更新新版本博客,更新内容很多,因此新开了一篇博客,戳这里. 1 概述 使用spring boot作为后端框架与Android端配合mysql进行基本的交互,包含了最基本的增 ...
- 混合开发的大趋势之一React Native与Android联调
转载请注明出处:王亟亟的大牛之路 先安利,有空我都会更,看到的好东西都会放进来:https://github.com/ddwhan0123/Useful-Open-Source-Android 公司某 ...
- 后端Spring Boot+前端Android交互+MySQL增删查改(Java+Kotlin实现)
1 前言&概述 这篇文章是基于这篇文章的更新,主要是更新了一些技术栈以及开发工具的版本,还有修复了一些Bug. 本文是SpringBoot+Android+MySQL的增删查改的简单实现,用到 ...
- Android+Java Web+MySQL实现登录注册
1 前言&概述 这篇文章是基于此处文章的更新,更新了一些技术栈,更加贴近实际需要,以及修复了若干的错误. 这是一个前端Android+后端Java/Kotlin通过Servelt进行后台数据库 ...
- Android随笔之——Android时间、日期相关类和方法
今天要讲的是Android里关于时间.日期相关类和方法.在Android中,跟时间.日期有关的类主要有Time.Calendar.Date三个类.而与日期格式化输出有关的DateFormat和Simp ...
- Android App的设计架构:MVC,MVP,MVVM与架构经验谈
相关:http://www.cnblogs.com/wytiger/p/5996876.html 和MVC框架模式一样,Model模型处理数据代码不变在Android的App开发中,很多人经常会头疼于 ...
- Android 强烈推荐:程序员接私活那点事
今天周末在家宅着,并不是我不想运动,是因为北京的雨雪交加导致我想在家写文章,不过想想给大家写文章还是蛮惬意的,望一眼窗外,看一眼雪景,指尖在键盘上跳动,瞬间有种从屌丝程序员转变成了小姑娘们都羡慕的文艺 ...
- 微信app支付(android端+java后台)
本文讲解使用微信支付接口完成在android开发的原生态app中完成微信支付功能, 文章具体讲解了前端android如何集成微信支付功能以及后台如何组装前端需要支付信息, 话不多话, 具体看文章内容吧 ...
随机推荐
- Altera自带的RAM仿真学习
(1)单口RAM 1.无读使能rden信号的ModelSim功能仿真: 在不使用读使能rden信号的情况下,单口RAM仿真结果表明: 1.写使能wren为高时,写数据操作有效: 2.写使能wren为低 ...
- windows下python调用c文件流程
1.新建fun.c文件和fun.h文件 #include <stdio.h> #include <stdlib.h> #include <string.h> int ...
- Java字段初始化规律:
Java字段初始化规律: Java进行初始化的地方有两个,初始化块和构造函数,其中初始化块又分为静态初始化块和实例初始化块(以上程序为实例初始化块).静态初始化块是类中由static修饰的初始化块,实 ...
- 吐槽 坑爹的MySQL安装路径选择
一般再windows下面安装MySQL我们都会选择msi安装模式,然而安装最新版的MySQL(mysql-installer-community-5.7.11.0.msi 下载地址)发现MySQL默认 ...
- vi高级命令集锦
.交换两个字符位置 xp .上下两行调换 ddp .把文件内容反转 :g/^/m0/ (未通过) .上下两行合并 J .删除所有行 dG .从当前位置删除到行尾 d$ .从当前位置复制到行尾 y$ 如 ...
- 【转载】iptables、tc和ip命令
2.3 CommandListener中的命令 CL一共定义了11个命令,这些命令充分反映了Netd在Android系统中网络管理和控制方面的职责.本节首先介绍Linux系统中常用的三个网络管理工具, ...
- 【Head First Servlets and JSP】笔记8:监听者
1.你不用了解所有监听者API,并不多,一共有8个.不过,你需要知道你能监听什么,以便在需要的时候可以查. 2.关于Session和Cookie.参见JavaWeb学习总结(十二)——Session ...
- linux的文件,目录操作命令(mv,rm,cp)
1.mv :用于重命名文件或目录:用于转移文件或目录 重命名文件或目录:$mv filename overfile ; $mv dirname overdir(必须是当前目录下没有的,否则操作的是转移 ...
- 20145231《Java程序设计》第四次实验报告
实验四 Android开发基础 实验内容 •安装Android Studio •运行安卓AVD模拟器 •使用Android运行出模拟手机并显示自己的学号 实验步骤 一.安装Android Studio ...
- linux下安装casperjs 开发运行环境
casperjs是一个基于phantomjs的测试框架,使用python进行操作,所以一个完整的casperjs环境需要安装phantomjs和python. 1 phantomjs安装 到官网下载最 ...