安装后,按F12,打开firebug
找到脚本,启用脚本。
找到要调试的JS文件
在需要断点的地方,鼠标点下左侧
会出现一个红点
执行到这里的时候,就会进行调试了
很多时候,我们在进行移动端开发时,都是先在PC端使用手机模拟器进行调试,没有问题后,我们才会在手机端的浏览器进行测试,这个时候,如果没有出现问题,皆大欢喜。但是一旦出现问题,我们就很难解决,因为缺乏可视化的界面。不似在PC端,我们能直观的去改变样式,或者是进行断点调试。
这里主要介绍三种方法:
1、Chrome DevTools(谷歌浏览器)的模拟手机调试
2、IOS Safari真机调试
3、Chrome DevTools远程调试Android
这种调试方式不仅能用于模拟手机调试还是主要的PC端页面调试的方式,这里主要说用于手机调试。
a.谷歌浏览器的开发者工具,可以参照下图右键选择”检查“或者使用快捷键F12,打开开发者工具。
b.打开后看到类似如下界面的开发者调试界面,Elements可以查看文档元素,Console可以在线调试js和查看输出结果,Sources可以调试JS和查看依赖资源,Network查看所有的网络请求等等。
c.如果没有需要模拟的机型怎么办?可以增加,点开机型设置面板,选择edit,然后可以在右方修改展示机型,如下:
d.还可以模拟不同网络情况。
a.使用数据线将 iPhone 与 Mac 相连
b.iPhone 开启 Web 检查器(设置 -> Safari -> 高级 -> 开启 Web 检查器)
c.iPhone 使用 Safari 浏览器打开要调试的页面(以兰亭单品页为例)
d.Mac 打开 Safari 浏览器调试(菜单栏 —> 开发 -> iPhone 设备名 -> 选择调试页面)
如果你的菜单栏没有“开发”选项,可以到左上角 Safari -> 偏好设置 -> 高级 -> 在菜单栏中显示“开发”菜单。
e.在弹出的 Safari Developer Tools 中调试。
经过如上步骤就可在 Mac 端调试 iPhone 上 Safari 运行的页面了。
a.在 Chrome 浏览器地址栏中输入 chrome://inspect/#devices 并回车,就可以打开 Inspect 调试界面,此时我们勾选Discover USB devices 选项便可以看到设备列表。
b.然后打开手机中开发者选项并打开 USB 调试开关(具体方法自行百度,不同手机有一定区别),使用数据线将手机连接到电脑上,我们就可以在设备列表中看到自己的设备。
c.这时,打开手机上的Chrome 浏览器,随便打开一个网址(以兰亭单品页为例),设备列表中你的设备下便会出现你打开的页面。
d.此时我们点击 inspect 选项。
e.接下来你便可以和调试 PC 界面一样通过 Chrome 进行你所需要的调试,你在左侧屏幕上做的一切操作和你的手机上的操作会始终保持同步,如果你嫌左边这块多余,也可以关闭 Toggle Screencast 只保留控制台本身。
一、seajs.config配置说明:1.base说明:
base是字符串类型,表示基础或叫做根路径(最好绝对地址)
备注:
(1)base如果不写的话是根据你引用sea.js的地址目录
(2)base如果写了’.’或者 ‘/’或者’ ’这些,会默认从服务根目录开始
(3)base如果写了’js/’之类的相对路径,会默认根据你引用sea.js的地址目录
例如:
seajs.config({
base: 'http://example.com/path/to/base/'
})
2.alias说明
例如:
seajs.config({
base: 'http://example.com/path/to/base/',
// 别名配置
alias: {
'es5-safe': 'gallery/es5-safe/0.9.3/es5-safe',
'jquery': 'jquery/jquery/1.10.1/jquery'
}
})
引入的时候:加载模块(seajs.use("es5-safe")) 引入模块 :(require("jquery"))
3.paths说明:
当目录比较深,或需要跨目录调用模块时,可以使用paths来简化书写。
例如:
seajs.config({
base:'http://example.com/path/to/base/',
//表示路径配置
paths:{
'cwd':'static/common/js'
},
alias: {
'es5-safe': 'gallery/es5-safe/0.9.3/es5-safe',
'jquery': 'jquery/jquery/1.10.1/jquery',
'jquery':'cwd/common/jquery-1.11.3'//alias中使用 static/common/js/common/jquery-1.11.3
}
})
seajs.use('cwd/project/AA')//static/common/js/project/AA
var index = require(cwd/index)// static/common/js/index.js
4.map说明:
map是Array类型,表示配置可对模块路径进行映射修改,可用于路径转换、在线调试等。
例如:
seajs.config({
map: [
//[ '.js' , '-debug.js' ]
['.js' , '.js?_t='+(new Date).getTime()]
]
})
define(function(require, exports, module) {
var a = require('./a')
//=>加载的是 path/to/a-debug.js
})
5.preload说明:(备注该属性在V2.3版本时候去除了)
preload是Array或String类型,表示预加载项,可以在普通模块加载前,提前加载并初始化好指定模块。
备注:preload中的空字符串会被忽略掉。使用时需要等到 use 才加载
例如:
seajs.config({
preload: ["jquery"]
})
6.debugBoolean 调试使用
值为 true 时,加载器不会删除动态插入的 script 标签。插件也可以根据 debug 配置,来决策 log 等信息的输出。
seajs.config({
debug:true
})
7.vars变量配置
有些场景下,模块路径在运行时才能确定,这时可以使用vars变量来配置。
seajs.config({
vars: {
'locale': 'zh-cn'
}
})
define(function(require, exports, module) {
var lang = require('./i18n/{locale}.js')
//=>加载的是 path/to/i18n/zh-cn.js
})
vars配置的是模块标识中的变量值,在模块标识中用{key}来表示变量。
二、 define
1.所有模块都通过 define 来定义
define(function(require, exports, module) {
(1). // 通过require.async引入依赖(引入模块)
require.async是异步加载的在引入后,的回调函数中才能使用,函数返回值就是require对象
require.async("jquery",fun) 异步加载模块 jquery(别名) fun回调函数(可选参数)
require.async(['lib/common/common.js','lib/common/index.js'],function(){
Echo.init({
offset: 150, //离可视区域多少像素的图片可以被加载
throttle: 10 //图片延迟多少毫秒加载
})
}) //调用多个模块 fun回调函数可选()
(2).require引入依赖(引入模块)
Require引入就可以使用
var Spinning = require('lib/common/common.js') 基础地址/lib/common/common.js
Spinning.tostring() 调用Spinning里面的tostring方法
require直接引入整个文件
require.async(["swiper"], function() {
require('module/Mycenter/mycenter')
})
2.对外暴露接口
// 通过exports对外提供接口
exports.tonumber = function(){ var a = 0}
// 或者通过module.exports提供整个接口 (推荐使用)
module.exports.tonumber = function(){ var a = 0}
})
三 、use()
seajs.use 用来在页面中加载模块。通过 use 方法,可以在页面中加载任意模块。use 的模块路径相对于当前页面
语法:seajs.use(id, callback?)
// 加载模块 main,并在加载完成时,执行指定回调
seajs.use(‘./main’)加载模块
seajs.use(‘./main’, function(main) {
main.init()
})
use 方法还可以一次加载多个模块:
// 并发加载模块 a 和模块 b,并在都加载完成时,执行指定回调
seajs.use(['./a', './b'], function(a, b) { 加载多个模块 fun回调函数(可选参数)
a.init()
b.init()
})
四、注意
引入 sea.js 时,可以把 sea.js 与其他文件打包在一起,可提前合并好,或利用 combo 服务动态合并。无论哪一种方式,为了让 sea.js内部能快速获取到自身路径,推荐手动加上 id 属性: