首页 > 其他分享 >移动端前端开发调试

移动端前端开发调试

时间:2023-07-20 20:32:34浏览次数:68  
标签:浏览器 Chrome 测试 Android 移动 前端开发 调试 页面


通过移动端使用 Web 服务的比率越来越大,例如淘宝 2014 年双十一,移动端交易份额就达到 42.6%。由此可见,掌握移动端的前端开发和测试是非常有必要的。

本文只介绍与调试有关的内容,至于其他移动端开发知识(技巧、坑)太多太大,推荐 Mars 移动前端开发知识库。这个项目很久没有大动静了,欢迎大家猛烈关注,不要让它“太监”了。

由于本文较长,如果没有太多时间和精力查看,建议跳转到 不同测试场景下需要用到的技术和工具 一节,找到适合自己测试需求的场景,再查阅相关章节。

响应式测试

响应式现在基本是中小型项目的标配了,先来谈谈响应式测试技巧。

基础的响应式测试

响应式的测试特别简单,通过改变视窗大小(也就是缩放你的浏览器)即可测试。当然,你的 CSS 中 Media Queries 判断条件设置时要使用 max-width才行,如果使用 max-device-width 则会根据你设备的屏幕尺寸来判断。区别详情请看 这里

对于 Chrome 浏览器,你可以将 Chrome DevTools 放在右边,这种布局方式尤其适合用在外接的大屏幕上。然后通过拖动 DevTools 快速测试响应式的显示效果:

优点就是对于 Chrome 开发者可以快速查看响应式变化效果。缺点就是分辨率尺寸不会很精确,因为它的页面宽度是添加了滚动条之后的宽度,这样对 Media Queries 的临界值效果不好测试。

对于 Firefox 浏览器,不愧是早期开发的必备神器,它早就内置了响应式测试工具,可以通过 Firefox 工具 -》Web 开发者 -》自适应设计视图

可以设置分辨率等参数,以及模拟 touch

由于响应式测试太简单,于是有了一大堆的书签栏 JS 工具或者 Chrome 扩展,并且以很多交互特效、复杂的功能来吸引用户。实际上使用起来,你可能需要依靠网络才能使用,还会遇到切换缩放不够流畅、刷新不方便等等问题,在这里不推荐。

Chrome 模拟设备尺寸

如果你需要测试某种明确的机型,Chrome 新版的 Emulation 就可以派上用场了。Emulation 现在变成了一个手机图标(

),之前的 Emulation 面板被放在了 DevTools 的分裂视图中了,如果你怀念以前的Emulation 面板或者需要模拟地理位置、加速计等功能,在 DevTools 界面摁下 ESC

在 Device 你可以选择预置的设备,快速切换分辨率和屏幕有关参数。此外还可以设置分辨率比率,来模拟 Retina 或者更高级屏幕下的效果,这样可以测试你的响应式图片是否被正确替换等。它甚至提供了网络测试,来测试低网速情况下你的页面加载情况。慢网速的测试,往往需要用抓包工具(Charles 等)来模拟,现在用 Chrome 也可以模拟了。

除此之外,Chrome 的手机模拟器还提供了非常非常多的实用功能,比如模拟 touch 事件、捏等手势操作、地理位置、加速计、Retina 等等,详情请见 官方文档,英文不好的朋友可以看我的 翻译版本。节约篇幅,这里不再赘述。

这里的方法仅能作为基础的响应式测试,对于中小型、比较简单的项目,完全足够用了,对于稍微复杂的页面,还是需要用虚拟机或者真机测试,这样更加可靠。

基于 Android 的移动端前端开发调试

Android 系统是份额最大的移动端设备操作系统。一方面,Android 是 Google 开发的,浏览器等也是基于 Blink 内核(早期版本基于 Webkit ),都是 Google 开发的,所以技术上应该是没有问题的。另一方面,Google 无偿开源 Android 系统,结果导致很多小厂商自己乱改 Android 系统,各种版本遍地生花,各种 BUG 层出不穷。

Android 虚拟机测试

在电脑上安装 Android 虚拟机,就可以用虚拟机打开进行测试。一般推荐两个:

Genymotion

Genymotion是一个很棒的 Android 虚拟机。但是首次安装配置需要麻烦一些。由于基于 VirtualBox 内核,所以要先安装 VirtualBox,然后需要注册账号 Genymotion,可以免费使用,但是有功能限制。如果遇到重要的项目,临时买一两个月高端账号也是 OK 的。

安装完成,登陆之后,选择 Android 版本和手机型号,即可下载对应的虚拟机包,下载好的虚拟机会显示在列表中,你可以选择开启。

安装好的虚拟机与你 Host 本机处于一个局域网,这样你就可以用 BrowserSync 之类的,开启一个局域网 IP 本地服务器,在移动设备上同步测试了。关于 BrowserSync,如果你没接触过,下面有讲。

比较蛋疼的是,Genymotion 虚拟机里面安装 APP 好像比较麻烦,安装 Chrome 不太方便,这样不方便连接桌面版 Chrome 进行调试,只能使用 Weinre 调试。如果你有 Genymotion 使用这方面的经验欢迎分享。

Parallels

Parallels 是基于 Mac 平台的虚拟机,使用它创建虚拟机的时候,可以直接下载 Android 系统并安装,超级傻瓜的操作,但是超级好用。

没错,它还可以装 Chrome OS,只需要点击一下等待下载即可。

其他虚拟机软件应该也可以实现,不如这两种好用,如果这两种你无法使用,可以自行搜索选择其他方法尝试。Win 系统可以直接安装 Android SDK 也可以通过虚拟机方式,这里不再赘述。

安装完虚拟机,就可以用里面的浏览器打开网页进行测试了,虚拟机与本机处于一个局域网,可以用局域网 IP 来调试本地页面。

虚拟机不是真机,但是要比直接用浏览器测试强一些,在桌面操作比较方便,还可以安装多个版本测试。

Android 真机调试

桌面端的前端开发调试非常简单,因为有 Firebug、Chrome DevTools 等工具,直接右击打开就可以看到元素的 CSS,并且可以查看各种资源、修改运行调错 JS 等。而移动端浏览器显然没法带有这些功能,于是可以用数据线连接设备,然后用电脑上的 Chrome DevTools 来调试移动设备上的页面。

首先,你的 Chrome 版本必须高于 32。其次你的测试机 Android 系统高于 4.0,测试机安装 Chrome for Android 才可以使用 Chrome 远程调试这项功能。

先用数据线将 Android 测试机连接到电脑上。需要打开测试机上面“开发者选项”中的 “USB 调试”功能。在 Android 4.2+ 系统上“开发者选项”默认是隐藏的,所以你需要先开启“开发者选项”(开启方法:设置 -》 关于本机 -》猛击版本号(Build number)多次 即可开启开发者选项)。之后如果没有开启,或者没有反应,可能是你的版本问题或者点击错了,你可以尝试把 关于本机然后在桌面版 Chrome 打开 chrome://inspect

此外,还可以直接在桌面版 Chrome 输入 URL 在移动设备上打开;在本地用 Nodejs 或者其他功能开启一个本地服务器,用端口转接让移动设备直接访问本机 localhost 上的页面,再配合 LiveReload、BrowserSync 之类的工具,自动刷新,测试简直爽歪歪。

更多细节不再赘述,可以查看 Remote Debugging 官方文档 或者我的 翻译版本

Android WebView 前端开发调试

现在越来越多的移动端 APP 是 WebView,因为开发方便,更新快捷。那么就会有调试 WebView 的需求,因为他们本身就是网页。

基于 Chrome 的调试

在 Android 4.4(KitKat)或者更新版,你可以使用 DevTools 来调试原生安卓应用中的 WebVies 内容。

不过需要在你开发的应用中,添加有关代码才可以启用 WebView 的调试,这里比较有局限性,有兴趣的朋友可以参照 官方文档 或者我的 翻译版本 试下,这里不再赘述。

使用 Weinre 调试

Weinre 是一个相当简单好用的调试工具。它会在你本地创建一个监听服务器,并提供一个 JavaScript,你只需要在需要测试的页面中加载这段 JS,就可以被 Weinre 监听到,在 Inspect 面板中调试你这个页面。

目前 Weinre 也发布到 NPM 上了,Mac 下具体使用方法如下( Win 的同学请参加:远程调试工具-weinre):

首先安装 Weinre:

npm install -g weinre

安装完成之后,要在本地开启一个监听服务器,需要获取本机的局域网地址:

  • Mac 在终端执行 

ipconfig getifaddr en0

  • Win 在命令行执行 

ipconfig这时候拿到一个 IP,就本例而言,我的 IP 为 10.189.249.254,这时候执行:

weinre --boundHost 10.189.249.254

开启本地监听服务器。

这里有一个网址,就是 Weinre 的一些说明,我们可以打开看下:

这里最重要的是箭头所指的 <script src="http://10.189.249.254:8080/target/target-script-min.js#anonymous"></script>小提示:这个 JS 后面的 #anonymous 起到一个标识作用,为了区别,我们可以将其修改成 #test 放到页面中。这时候,我们的 Inspect 面板的地址就不是 http://10.189.249.254:8080/client/#anonymous 了,而是 http://10.189.249.254:8080/client/#test

当我们访问页面的时候,就会出现在监听列表中,如果有多个网页,你可以从列表中选择一个。然后就可以使用后面的 Elements、Console 等面板来进行调试操作了:

Weinre 非常灵活,只需要在页面中加载这个 JS,然后访问即可,因此 WebView 可以用这种方法调试,一些低版本的 Android、iOS 也可以支持,Window Phone 也是可以用的。在调试移动设备时你可能需要在本地搭建一个局域网 IP 的服务器,将设备与本机网络连接成一个局域网,用移动设备访问这个网页即可。

当然 Weinre 也不是万能的,相比 Chrome 的调试工具,它缺少 JavaScript debug 以及 Profiles 等常用功能,但是它兼容性强,可以实现基础调试功能。

基于 Chrome 的测试是鸡肋的

Chrome 功能很强大,调试很方便,提供了很多调试功能。但是前提是安装 Android 版本的 Chrome 浏览器,才可以连接调试。

之所以说它鸡肋,是因为并不是所有用户都使用 Chrome 浏览器,这一点尤其体现在国内。国内用户大都使用 UC 浏览器、百度浏览器以及 QQ 手机浏览器等等(数据报告),而这些浏览器通常使用的是 WebView,或者自己改造的内核。而 Chrome 作为最强大的浏览器,在它上面测试通过并不表示在当前 Android 的内置浏览器正常,通常内置浏览器功能会比较弱。

此外国内用户也有一定的比例使用微信、手机 QQ 等的内置浏览器来访问网页,使用的是 WebView 借用原生浏览器(有待进一步测试考证)。也有人测试说如果安装了 QQ 手机浏览器,那么微信、手机 QQ 里面的浏览器就使用 QQ 手机浏览器的内核。这些都造成了 Android 下面移动端调试的难度和复杂度。

因此,你需要分析你的用户使用份额,然后进行测试,而不能仅仅在最新版测试 Chrome。从这一点来看,Weinre 是最折中实用的测试方案。

基于 iOS 的移动端前端开发调试

iPhone 等一系列苹果设备对前端还是相当友好的,性能够好,Safari 浏览器也是不错,型号固定统一,问题也比较好解决,此外苹果公司也提供了一系列开发者工具。

Safari 默认是隐藏开发选项的,在第一次使用的时候,需要在 Safari 中选择 “偏好设置”-》“高级”-》“在菜单栏中显示开发选项”:

使用 iOS Simulator 调试开发

iOS Simulator 是 Xcode 开发工具内置的 iOS 模拟器,因此该功能仅能在 Mac 系统下使用。按照如下方式即可打开:

打开之后,你可以用模拟器里面的 Safari 打开需要调试的网页。它可以直接打开本地 localhost 的页面,无须任何设置。你可以选择上面菜单中的“硬件”来模拟其他 iOS 设备,包括 iPad 等。如果你升级了你的 OS X 系统和 Xcode 6,你还可以模拟 iPhone 6 和 iPhone 6 Plus。

如果需要调试,打开桌面版的 Safari,在“开发”中选择要调试的页面,即可打开 Safari 调试面板:

这样就可以进行调试了。这里提供一个技巧:将 URL 粘贴到模拟器的地址栏时,用 CMD + V 是无法粘贴进去的。如果想要粘贴,先摁下 CMD + V 然后再用鼠标点击一下地址栏,稍等会出现 Paste

iOS 设备真机调试

模拟器已经足够强大方便了,但有些手势操作测试以及最真实的用户体验测试还是需要真机。Safari 调试真机上的网页也是非常简单的。

首先需要在 iPhone 等设备上设置一下 Safari 浏览器,开启调试功能。具体步骤:“设置”-》“Safari”-》“高级”-》“Web 检查器”。使用数据线连接电脑,在设备上用 Safari 浏览器打开需要调试的页面,之后在桌面版的 Safari 开发选项中即可看到进行调试,跟用 iOS Simulator 一样,只不过现在换成了真机。

但是调试本地网站,你可能要将手机与电脑连在一个局域网内,然后开启一个局域网 IP 的服务器进行调试,稍微麻烦。

此外 Safari 还可以调试在 iOS 上面的 WebView,比如用调试 PhoneGap 打包的 APP 等,方法类似,这里 还有个测试用 APP,会 iOS 开发的朋友可以看下。

提示:iOS 系统版本 8+ 的设备,需要使用 Safari 7.1+ 调试,老版本 Safari 会无法识别。你可以将 OS X 更新到 10.9.5,或者升级到 Yosemite。具体可以看 这里

使用 MIHTool 进行远程调试

MIHTool 是国人 听奏 开发的,基于 Weinre,用于 iOS 设备的前端开发测试。

上面有提到 Weinre 大体的工作方式,即开启一个服务器,然后将 JS 插入到页面中,访问进行调试。MIHTool 将这个过程简化了,它是一个 APP,可以直接安装到你的 iOS 设备里面,然后内置一个简单的浏览器可以打开你的测试页面,当它开启时,会自动向页面中插入 Weinre 的 JS,并告知 Weinre 控制台 URL 等信息,让你可以访问进行调试。

它还提供了一个公共的 Weinre 调试服务,生成类似 http://i.mihtool.com/dev/client/#AwAj

除此之外,它还提供了很多方便调试的功能,有兴趣的朋友可以看下 官方网站的介绍 和 Debugging web content on iOS。感觉就是丑了一些,如果能请设计师或者交互设计一下,会好得多。

微信 Webview 调试

微信目前有非常大的移动端页面市场占有率,因此很多页面特别是面向微信的页面,就需要微信调试。

微信的官方开发团队也非常给力,针对各种需求,编写、提供了非常多的资料和工具。具体内容可以看下他们的官方网站:微信调试工具。其余的不再赘述。

感谢 李耀力 同学提供该信息!

移动设备在线测试

移动端设备如此之多,小公司或者团队,没有这么多资金和精力购买如此多的测试设备进行测试。于是就有人买了这些设备,连接起来,提供在线调试服务。

例如用不同的设备访问你的网站,并截图:

甚至可以让你远程控制一台机器,进行测试操作:

BrowserStack 就提供这种服务,它可以实时在线调试,也可以 截屏测试响应式 等等。

此外 Keynote 也提供这种服务,当然这里的 Keynote 不是 Mac 上的幻灯片 APP。它提供更加真实的 Mobile 测试,我简单的试了一下,果然比较卡,应该是真机测试:

其他移动端调试方法和技巧

UC 浏览器测试

UC 浏览器是国内使用份额最大的移动端浏览器,值得高兴的是,它专门提供了开发版方便开发者连接调试。

当然配置起来稍微麻烦,但总比没有强的多。

配置和开发文档官方已经非常详细了,这里不再赘述,请移步官方网站

BrowserSync 同步操作

BrowserSync 是我最爱的多终端测试工具。在没有使用这个BrowserSync 之前的原始的测试流程一般是这样的:

先把本地的网页上传到远程服务器(因为好多设备都要去访问一个固定的地址),然后将网址输入到各个测试机的测试浏览器里面手动打开(或者使用浏览器插件等,生成二维码扫一下)。然后手机开始下载页面,需要等待下载。观看效果进行测试,每个测试机都要操作一遍。测试其他网页的时候,每个测试机重新输入网址、刷新。如果代码有修改,需要重新上传服务器进行刷新。

而 BrowserSync 这个工具,可以用你局域网 IP 创建一个本地服务器,生成一个类似http://10.189.249.135:3002

建议使用无线路由器搭建一个无线局域网,所有设备都连入这个无线局域网。Win 系统电脑用软件开启 Wifi 共享也是可以的,Mac 就比较悲剧了,只有在插网线的时候,可以开启 Wifi 共享功能。

BrowserSync 还会监听文件变动,当监听的文件发生变动,会自动刷新所有连接本地服务器的页面。BrowserSync 最主要的功能是同步,同步一切操作,当你在某个浏览器中触发的操作,会在所有测试浏览器中同步操作,例如在电脑上滚动页面,所有手机都会滚动页面;电脑上更换了 URL 测试另一个页面,所有手机都跳转到另一个页面。

应用 BrowserSync 工具之后的新版测试流程就变成这样了:

用 BrowserSync 开启本地服务器,所有测试设备连接到局域网中,依次打开http://10.189.249.135:3002/(BrowserSync 创建的本地服务器地址)。在一台设备操作,观察其他设备的情况,修改了 CSS、HTML 或者 JS 代码,保存一下,自动在所有设备自动刷新。

BrowserSync 的使用非常简单,在要创建服务器的目录下面执行:browser-sync start --server --files="*" 命令即可,表示创建一个服务器并监听该目录下的文件变动。它也有提供 Grunt 和 Gulp 插件,更多的用法移步 BrowserSync 官方文档,这里不再赘述。BrowserSync 的原理大体是这样的,它会在 HTML 页面里面插入 JS,然后监听页面操作。所以当你滚动页面或者跳转新页面,BrowserSync 可以捕获到这个操作,通过 Socket.io 向所有 Client 的 JS 发出操作指示,其他设备也会随之 scroll 或者 location.href

此外,两个 BrowserSync 的小提示:

  • BrowserSync 默认请求 

index.html

  • ,如果你的目录里面没有这个文件夹,会返回 

Cannot GET /

  • ,这时候你需要指定具体的目录、文件。
  • 在开启 BrowserSync 的命令中,

--files="*"

  •  表示要监听变动的文件。如果你指定了 

--files="css/*.css"

  •  就表示只监听 

css/

Charles 代理应用

Charles 是 Mac 系统下面的抓包、代理工具。如果你电脑是 Win 系统,可以使用 Fiddler 实现本节要介绍的技巧。

使用场景举例:当我们在本地开发时使用内网登陆功能(需要同域),往往需要绑定 Host,比如将本机127.0.0.1 绑定为 xx.xx.com。这样我们访问本地服务器时使用 xx.xx.com,才可以正常使用 登陆 等等服务(需要用到 Cookie)。

那我们用移动端设备测试这个页面的时候,也需要修改移动端设备上的 Host。因此 Android 需要 root,iPhone 需要越狱,而且每次都要开启,极为不方便。这时候,我们就可以使用 Charles 这里抓包工具做一个代理。

当打开 Charles 时,它会自动在本机开启一个代理服务,默认接口为 8888。这时候,我们设置同局域网内的移动设备的代理为本机局域网 IP,即可通过 Charles 转发请求,在移动设备上访问电脑可以访问的内容。基本原理如下图:

通过这个代理服务,移动设备的请求被转移到到电脑上发送出去,并将电脑得到的响应返回给移动设备。其他同类问题(想用手机访问只有电脑才能访问的内容)均可用这种方式解决。此外,因为经过 Charles 代理,因此可以使用 Charles 的查看有关请求和响应、做本地资源映射等等功能,来简化开发和调试 BUG。

启用方法详情请见:iOS开发工具——网络封包分析工具Charles 中的 截取iPhone上的网络封包 一节,这里不再赘述。

提供一个 Charles 的小技巧:Charles 只提供了全局监听和 Firefox 监听,但我常用的是 Chrome 浏览器,我只想监听 Chrome 浏览器中某个页面的请求信息,也可以通过设置代理来解决。这里使用 SwitchySharp 代理插件(GAE 翻         墙必备),增加一个新的情景模式,绑定本地 Charles 代理。

这样当我们想抓包某个页面时,只需要打开 Charles 并勾掉 Proxy-》Mac OS X Proxy 和 Mozilla Firefox Proxy,之后再在 SwitchySharp 中勾选这个情景模式,即可清爽的只监听 Chrome 浏览器发送的请求了。

关于 Charles 的使用,可以自行搜索教程,Fiddler 同样原理,不再赘述。

使用 Ghostlab 等集成测试工具

Ghostlab 是一个带着美观界面的集成的测试工具。大体功能相当于 Weinre + BrowserSync,带有简洁美观的界面,用鼠标拖动操作,简单几个点击即可启动一个本地局域网 IP 服务器,会监听网页的终端,并同步各种操作。当点击Inspect

带有界面使其使用十分简单,不需要执行命令,也有很多额外的参数来辅助调试。因此这个软件是收费的,而且只针对 Mac 平台。

更具体的可以看下 Ghostlab 官方网站,有一段介绍视频简洁明了的介绍了有关功能。

同类的产品还有 Adobe Edge InspectCC 和 GapDebug 功能类似各有特点,这里不再赘述。

回顾总结与扩展阅读

移动端前端重构项目开发流程最佳实践

新建项目相关文件,然后应用 BrowserSync 等工具(可以配合 Grunt 等)启动本地服务器。在 Chrome 中启用 Emulation 来模拟 iPhone 等设备的尺寸,进行编码开发。这样就可以无刷新、比较直观的看到手机上的效果。

开发基本完成,将测试机、虚拟机等打开联入局域网,输入本地服务器地址,开始测试。对文件的修改实时刷新在所有设备中,即时看到效果。

对于有点复杂的 BUG 或者有关问题,使用 Safari 或者 Chrome 连接虚拟机或者真机进行调试。分析用户浏览器使用习惯,针对相关浏览器等进行测试。

不同测试场景下需要用到的技术和工具

  • 响应式测试:Chrome DevTools 面板右侧拉伸快速查看效果;Firefox 响应式工具进一步调整;Chrome Emulation 精细测试。
  • Android 设备测试:使用 Android 虚拟机;优先使用 Weinre 测试,分析用户浏览器使用份额,有针对的进行测试。高版本 Android 测试机,使用 Chrome 连接调试。Android 4.4+ 的 WebView 修改 APP 源代码,也可以用 Chrome 调试。
  • 低版本系统和其他品牌手机以及 WebView:统统可以用 Weinre 来解决。
  • iOS 设备测试:使用 Xcode 自带 iOS 模拟器,使用 Safari 调试;WebView 也可以被电脑上 Safari 调试;测试机连接电脑,也可以用 Safari 调试;MIHTool 可以在 iOS 设备上使用,提供类似 Weinre 的调试功能。
  • 测试多种设备:BrowserStack 和 Keynote。
  • 使用 BrowserSync 可以创建本地局域网 IP 服务器,并同步操作、监听刷新,极大减少测试操作,提高测试效率。
  • 当移动端设备无法访问某项资源时,使用 Charles 做代理,通过电脑去访问。

扩展阅读与资料参考

本文不断更新,如有错误、补充,请随时评论或者联系本人。

标签:浏览器,Chrome,测试,Android,移动,前端开发,调试,页面
From: https://blog.51cto.com/u_2700990/6791092

相关文章

  • 在调试状态下使用本机ip访问webapi
    1、在调试模式下无法通过ip访问webapi,但是可以使用localhost或者127.0.0.1加端口访问   2、因为在调试模式下运行它,Vs2022默认正在使用IIS-Express。默认情况下,IIS-Express仅绑定到localhost. 3、为了调试状态可以通过ip访问,需要打开位于以下位置的IIS-Express应用......
  • idea调试go语言
    使用IDE调试Go语言介绍在开发过程中,调试是一个非常重要的环节。调试可以帮助我们快速定位和解决问题,提高代码的质量和效率。本文将介绍如何使用IDE来调试Go语言程序,以帮助开发者更加高效地进行调试工作。Go调试工具在开始之前,我们需要了解一些与Go调试相关的工具。DelveDelve......
  • TQ3568 Buildroot文件系统终端上支持中文显示调试方法
    TQ3568Buildroot文件系统终端上支持中文显示调试方法修改busybox配置单如果是buildroot则makebusybox-menuconfigARCH=arm64diff--gita/rootfs/buildroot/package/busybox/busybox.configb/rootfs/buildroot/package/busybox/busybox.configindex02b1ee1..abc857e10064......
  • WPF调试软件窗口顶部工具栏的开起与关闭
    WPF调试软件窗口顶部工具栏的开起与关闭应用内工具栏可以实现元素选取,XAML热重载,绑定异常检测等功能工具栏->选项......
  • DL100 PN替换 DL100 RS422调试实例
    第一部分:现场问题描述 客户使用DL100的422通讯,需要西门子PLC使用过多422模块,PLC接入模块数量有限。换成DL100的PN通讯,使用交换机来处理。同时之前的使用中,遇到了DL100烧坏的问题。 第二部分:现场工作内容 1. 产品自身功能和参数设置体现: 接线:422通讯的接......
  • 【腾讯 TMQ】移动 APP 测试用例设计的关注点
    应用的启动和停止1.1首次启动是否出现欢迎界面,欢迎界面的停留时间合理,欢迎界面后是否正常进入应用;首次启动时间是否合理;该拉取的信息是否正确;桌面图标是否创建成功,功能启动快捷键创建是否成功(某些安卓手机会有在桌面创建应用内某个功能的快捷键的需求)1.2二次启动启动时间是......
  • N58(4G模块)通过AT指令连接TCP数据传输调试记录(1)
    背景有方科技的N58-CA4G模块+以太网+TCP客户端+SSCOM串口助手+AT指令的方式调通TCP通信开发流程1.模块初始化2.非透传TCP客户端通信流程一.模块初始化1.模块初始化2.非透传TCP客户端通信流程小tips:代码主要是按照流程复现,初始化代码可以使用例程通用代码其中会用到一些调用函数,包......
  • windbg配置网络版双机调试【转】
     一丶配置以及简介1.1简介与配置​windbg配置双机调试从来都是有很多方式。比如之前的是串口模式。现在我写一篇利用网络来进行配置的双击调试。首先准备的工具以及流程如下1.准备一台虚拟机。里面安装window1064版本(我是64,这个随意)itllyou上下载即可2.window......
  • Whistle(基于Node实现的跨平台转包调试工具)的使用
    可抓包,可显示vconsolet调试一、安装npmi-gwhistle二、启动手机和电脑处于同一网络w2start--init浏览器打开地址:http://127.0.0.1:8899/三、配置Rules:https://testh.app.coc.10086.cnwhistle.inspect://vConsoleconsole安装插件: w2installwhistle.ins......
  • 拷贝构造函数 和 移动构造函数 深拷贝
    采用了深拷贝的方式,obj2 和 obj3 的 data 成员变量指向不同的内存空间,因此可以独立地释放资源而不会出现重复释放的问题.classMyClass{public:int*data;intsize;//默认构造函数MyClass():data(nullptr),size(0){}//拷贝构造函数(深拷......