示例用法
January 13, 2024About 2 min
示例用法
本主题提供了一个简短的代码示例,说明如何使用云眼特性标帜(Feature Flag)AB实验 JavaScript(浏览器)SDK 来评估特性标帜(Feature Flag)、激活 A/B 测试或功能测试。
安装 SDK 后,将 Eyeofcloud 功能实验库导入代码,获取云眼特性标帜(Feature Flag)AB实验项目的数据文件,并实例化客户端。然后,可以使用客户端评估标帜规则,包括 A/B 测试和标帜传递。
此示例演示了以下每个概念的基本用法:
使用 Decide 方法计算具有键
product_sort
的标帜。作为副作用,Decision函数还会向云眼特性标帜(Feature Flag)AB实验发送决策事件,以记录当前用户已暴露于实验。有条件地执行特征代码。有以下几种选择:
- 获取标帜启用状态,然后检查标帜上名为
sort_method
的配置变量。SDK 会评估标帜规则,并确定用户所处的标帜变体,从而确定他们应该看到的排序方法变量。 - 获取标帜变体,然后运行“控制”或“处理”代码。
- 使用事件跟踪跟踪名为
purchased
的事件。此转化事件衡量实验的影响。使用 Track Event 方法,购买会自动归因于我们做出决策的正在运行的 A/B 测试,SDK 会通过可自定义的事件调度程序向 Eyeofcloud 功能实验发送网络请求,以便我们可以将其计入“结果”页面。
使用 NPM
const eyeofcloud = require("@eyeofcloud/eyeofcloud-sdk");
const eyeofcloudClient = eyeofcloud.createInstance({
sdkKey: "<Your_SDK_KEY>" // Provide the sdkKey of your desired environment here
});
eyeofcloudClient.onReady().then(() => {
var attributes = { logged_in: true };
var user = eyeofcloudClient.createUserContext('user123', attributes);
var decision = user.decide('product_sort');
var variationKey = decision['variationKey'];
if (variationKey === null) {
console.log(' decision error: ', decision['reasons']);
}
var enabled = decision['enabled'];
if (enabled) {
var sortMethod = decision.variables['sort_method']; // execute code for sort method value
}
if (variationKey === 'control') {
// Execute code for control variation
}
else if (variationKey === 'treatment') {
// Execute code for treatment variation
} // Track an event user.trackEvent('purchased');
});
使用 HTML 脚本标记
<html>
<head>
<title>Hello world</title>
<!-- Install Eyeofcloud SDK -->
<script src="https://unpkg.com/@eyeofcloud/eyeofcloud-sdk/dist/eyeofcloud.browser.umd.min.js"></script>
<!-- Add your datafile using your SDK key so you can later instantiate an Eyeofcloud client -->
<script src="https://cdn.eyeofcloud.com/datafiles/<Your_Sdk_Key>.json/tag.js"></script>
</head>
<body>
<h1>Hello world</h1>
</body>
<script>
// instantiate an Eyeofcloud client from the datafile
var eyeofcloudClient = window.eyeofcloudSdk.createInstance({
datafile: window.eyeofcloudDatafile
});
var attributes = { logged_in: true };
var userId = 'user123';
var user = eyeofcloudClient.createUserContext(userId, attributes);
var decision = user.decide('product_sort');
var variationKey = decision['variationKey'];
if (variationKey === null) {
console.log(' decision error: ', decision.reasons);
}
var enabled = decision['enabled'];
if (enabled) {
var sortMethod = decision.variables['sort_method']; // execute code for sort method value
}
if (variationKey === 'control') {
// Execute code for control variation
}
else if (variationKey === 'treatment') {
// Execute code for treatment variation
} // Track an event user.trackEvent('purchased');
</script>
</html>