使用「共用儲存空間」小程式執行 A/B 測試。
Shared Storage API 是適用於一般用途的跨網站儲存空間 Privacy Sandbox 提案,可支援許多可能的用途。例如 A/B 測試,可在 Chrome 104.0.5086.0 以上版本中進行測試。
您可以將使用者指派給實驗群組,然後將該群組儲存在共用儲存空間中,以便在跨網站環境中存取。
嘗試 A/B 測試
如要透過共用儲存空間執行 A/B 測試實驗,請確認您使用的是 Chrome 104.0.5086.0 以上版本。啟用 chrome://settings/adPrivacy
下的所有廣告隱私權 API。
您也可以在指令列中使用 --enable-features=PrivacySandboxAdsAPIsOverride,OverridePrivacySandboxSettingsLocalTesting,SharedStorageAPI,FencedFrames
旗標啟用共用儲存空間。
使用程式碼範例進行實驗
若想確認實驗能否帶來所需效果,您可以在多個網站中執行 A/B 測試。廣告客戶或內容製作者可以選擇根據使用者指定的群組顯示不同的內容或廣告。群組作業會儲存在共用儲存空間中,但無法洩露。
在這個例子中:
- 「
ab-testing.js
」應嵌入頁框中,而頁框會對應一個控制組和兩項實驗內容。指令碼會呼叫實驗的共用儲存空間工作程式。 ab-testing-worklet.js
是共用儲存空間工作程式,會傳回使用者獲派的群組,以決定要顯示哪則廣告。
// Randomly assigns a user to a group 0 or 1
function getExperimentGroup() {
return Math.round(Math.random());
}
async function injectContent() {
// Register the Shared Storage worklet
await window.sharedStorage.worklet.addModule('ab-testing-worklet.js');
// Assign user to a random group (0 or 1) and store it in Shared Storage
window.sharedStorage.set('ab-testing-group', getExperimentGroup(), {
ignoreIfPresent: true,
});
// Run the URL selection operation
const fencedFrameConfig = await window.sharedStorage.selectURL(
'ab-testing',
[
{ url: `https://your-server.example/content/default-content.html` },
{ url: `https://your-server.example/content/experiment-content-a.html` }
],
{
resolveToConfig: true
}
);
// Render the chosen URL into a fenced frame
document.getElementById('content-slot').config = fencedFrameConfig;
}
injectContent();
class SelectURLOperation {
async run(urls, data) {
// Read the user's experiment group from Shared Storage
const experimentGroup = await sharedStorage.get('ab-testing-group');
// Return the corresponding URL (first or second item in the array)
return urls.indexOf(experimentGroup);
}
}
register('ab-testing', SelectURLOperation);
應用情境
以上只是其中一部分的共用儲存空間用途。在收到意見回饋及發掘新的用途的同時,我們會繼續新增範例。
內容篩選
根據在共用儲存空間中收集到的資訊,在圍欄頁框中選取及顯示不同網站上的不同內容。這些用途的輸出門檻是選取網址。
- 廣告素材輪播:儲存資料 (例如廣告素材 ID、觀看次數和使用者互動),以判斷使用者會在各網站上看到哪些廣告素材。
- A/B 測試:您可以將使用者指派給實驗群組,然後將該群組儲存在共用儲存空間中,方便跨網站存取。
- 自訂使用者體驗:根據使用者的註冊狀態或其他使用者狀態,分享自訂內容和行動號召
產生摘要報表
使用「共用儲存空間」收集資訊,並產生雜訊的匯總報表。這些用途的輸出閘門是 Private Aggregation API。
- 不重複觸及率評估:許多內容製作者和廣告客戶會想瞭解有多少不重複觀眾看過他們的內容。使用 Shared Storage 可記錄使用者首次看見您的廣告、內嵌影片或出版品,並防止同一位使用者在不同網站上重複計算。接著,您可以使用 Private Aggregation API 輸出觸及率的摘要報表。
- 客層評估:內容製作者通常會想瞭解觀眾的客層。您可以使用共用儲存空間,在您擁有的位置 (例如第一方網站) 記錄使用者客層資料,並使用匯總報表製作其他許多網站的報表,例如嵌入內容。
- K+ 頻率評估:有時又稱為「有效頻率」,通常在使用者辨識或想起某些內容前,通常會需要觀看最低次數 (通常以廣告檢視畫面來說)。您可以使用共用儲存空間,針對曾看過內容片段超過 K 次的不重複使用者人數建立報表。
互動及分享意見回饋
共用儲存空間提案正在進行討論,因此可能隨時會有變動 如果您試用這個 API 並有意見,請不吝與我們分享。
- GitHub:閱讀 提案、觸及白皮書、提出疑問並參與討論。
- Shared Storage API 公告:加入或查看我們的郵寄清單過往公告
- 開發人員支援:您可以提問或參與 Privacy Sandbox 開發人員支援存放區。