dagger.js:从零开始

前情提要:dagger.js:可能是我见过的最简单易用的前端框架了

大家好,我是Tony。从本篇开始,我们逐步详细介绍如何使用dagger.js进行前端项目开发。

再次说明一下,dagger.js使用模块声明+描述式指令表达式进行工作,它直接运行在浏览器js运行时当中,无需编译过程。这意味着你无需预装任何构建工具或者包管理工具(包括但不限于node/npm/webpack/vite/babel...),当然也无需具备相关先验知识,就可以直接使用dagger.js上手开发web应用。

下面让我们打开代码编辑器,从零开始编写第一个dagger.js应用程序。

只需要创建一个空白的html页面,在head标签中引入dagger.js脚本:

<script type="module" crossorigin="anonymous" src="https://assets.codepen.io/5782383/dagger-1.0.0-RC.js" defer></script>

一个最基本的dagger.js应用就创建完成了。

接下来让我们添加几个基本指令,感受下dagger.js的工作方式。

在页面body标签中添加以下代码:

<div id="host" +load="{
  text: 'Hello dagger!',
  number: 1
}">
  <button id="btn" +click="alert($scope.number)">${ $scope.text }</button>
</div>

刷新浏览器,页面中将出现一个文本内容为“Hello dagger!”的按钮,点击按钮弹出alert弹窗,内容为数字1。

这个示例展示了dagger.js的生命周期指令+load和事件指令+click的基本用法:当div#host元素上声明的+load指令表达式返回值是一个有效对象时,相当于在以这个元素为根的作用域上创建了一个包含text字段的$scope对象,这个$scope对象可以在div#host元素和它子节点上的指令表达式中访问。当点击button#btn元素时触发事件指令+click指令表达式执行,弹出text的值。

你可以任意修改上面例子里+load或者+click指令表达式,验证结果是否符合预期。

与其他基于指令的框架(例如AngularJS和Vue.js)不同,在dagger.js应用程序中,并不存在组件(Component)实例的概念,指令的内容是一个上下文无关的普通js表达式,其执行结果由当前的作用域变量($scope)所决定。

为便于理解,我们将上面的例子改写成如下等价的javaScript代码:

// 使用立即执行函数创建封闭作用域
(() => {
    const $scope = { // +load指令
        text: 'Hello dagger!',
        number: 1
    };
    const button = document.querySelector('#btn');
    button.innerText = $scope.text; // 原地表达式${ $scope.text }
    button.addEventListener('click', () => { // +click事件指令
        alert($scope.number);
    });
})();

一句话总结本文知识点:+load指令可以创建作用域变量$scope,$scope在宿主节点和其子节点上的任意指令表达式中都可以使用。

在后续的章节里,我们将看到更多dagger.js指令的用法。

如果对dagger.js感兴趣的话,请您点赞收藏、分享本系列文章,也欢迎评论或者私信作者提出问题和建议。您的关注是对我最大的支持和鼓励。感谢您的阅读,祝工作学习顺利!

本文示例地址

注:本教程中的示例代码使用即将release的dagger-1.0.0-RC分支版本语法编写,与官网文档略有不同。

 下集预告:dagger.js:近水楼台先得月(作用域嵌套)

Dagger是网易杭州研究院QA团队开发的一个轻量级、运行稳定的WebUI自动化测试框架,主要基于Selenium及TestNg可以认为是对Selenium进行二次封装的一个框架(俗称 造轮子 )。之所以把这个轮子开源出来,主要在于经过了公司内部多个项目的实践,也取得了不错的成效,因此,希望开源以后可以对大家有所帮助及参考。 设计理念 Dagger首先是一个WebUI自动化框架,提供了赖以操纵浏览器的一些API。API数量不多,少于20个,但从实践上,已经基本涵盖95%的应用场景了(其余5%比较 个性 的自动化操作一般是封装在业务逻辑层面,有时候甚至会须要hack) Dagger其次是一个测试框架,使用TestNg管理和运行用例,TestNg相关断言内嵌于上述API中。因此,在我们的测试用例里面不应该看到单独的TestNg断言的 Dagger还是一种设计风格:简约。无论是Dagger框架本身还是基于Dagger编写的测试用例,都是十分light及straightforward的,以至于会让人感觉有点土。但实践中,这两者确保了低成本、易用性、可维护性 WebUI自动化从业界看,难推进,易烂尾,原因基本在于:维护成本高、运行速度慢、稳定性差 Dagger专注于WebUI自动化,从技术上克服了速度与稳定问题(见下文)。只封装够用的浏览器操作为API,并充分简化/强化这些API,以简约的风格去降低自动化的学习及使用成本。同时,在实践中,我们主要使用Dagger编写冒烟用例、其次是主干用例,少写逻辑复杂功能,不写边边角角功能,让用例也保持清爽(在整个自动化实施过程中,会定期进行用例Review),同样易于后期维护 主要特性 API极少,易于上手,详见这里. 提供比较完备的文档,便于快速入门,详见这里. 支持单机多浏览器并发执行,大大缩短用例执行时间,详见这里 通过修改TestNg源码实现失败用例自动重运行(详见这里)由此几乎消除WebUI自动化中常见的虚假失败 默认使用Chrome浏览器,原因详见这里 失败用例自动截屏 后续工作 加入Flex/Flash自动化支持 如何使用 Dagger十分适合中小型团队从零开始WebUI自动化,这样的话,只须要直接下载整个Dagger代码就行了,Dagger本身都已经配置好了,下载后看一下使用文档就可以直接开始写用例了 也可以把Dagger打成Jar包,导入已有的自动化框架中,详见这里 标签:Dagger  自动化测试
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值