مطالعه موردی Wake Lock API: افزایش 300 درصدی شاخص‌های قصد خرید در BettyCrocker.com

هیچ چیز هنگام آشپزی با دستگاه تلفن همراه بدتر از خاموش شدن صفحه نمایش آن در وسط یک مرحله دستور پخت نیست. بیاموزید که چگونه سایت آشپزی BettyCrocker.com از Wake Lock API برای جلوگیری از این اتفاق استفاده می کند.

برای نزدیک به یک قرن، بتی کراکر منبع آمریکا برای آموزش آشپزی مدرن و توسعه دستور پخت قابل اعتماد بوده است. سایت BettyCrocker.com که در سال 1997 راه اندازی شد، امروزه بیش از 12 میلیون بازدید کننده در ماه دارد. پس از اجرای Wake Lock API ، شاخص‌های قصد خرید آن‌ها برای کاربران wake lock در مقایسه با همه کاربران حدود 300 درصد بیشتر بود .

برنامه های بازنشسته iOS و Android

بتی کراکر که در سال 2014 با سر و صدای زیادی منتشر شد، اخیراً برنامه‌های آن‌ها را پس از حذف اولویت‌ها از اپ استور اپل و فروشگاه Google Play خارج کرد. برای مدت طولانی، تیم Betty Crocker اضافه کردن ویژگی‌های جدید به سایت تلفن همراه را به جای برنامه‌های iOS/Android ترجیح می‌دهد. پلتفرم فنی که برنامه‌های iOS/Android در آن ایجاد شده‌اند قدیمی بود و کسب‌وکار منابعی برای پشتیبانی از به‌روزرسانی و نگهداری برنامه‌ها در حال پیشرفت نداشت. برنامه وب همچنین از نظر ترافیکی بسیار بزرگتر، مدرن تر و بهبود آن آسان تر بود.

با این حال، برنامه‌های iOS/Android یک ویژگی قاتل داشتند که کاربران آن را دوست داشتند:

نکته حرفه‌ای آشپزی هزاره: برنامه تلفن همراه @BettyCrocker زمانی که دستور غذا را دنبال می‌کنید کم نور یا قفل نمی‌شود. — @AvaBeilke

80 درصد مردم با دستگاهی در آشپزخانه آشپزی می کنند، اما کم نور شدن صفحه نمایش و قفل شدن آن یک مشکل است. @BettyCrocker چه کرد؟ برنامه خود را به روز کرد تا زمانی که کاربران در دستور غذا هستند کم نور نباشد. - @Katie Tweedy

با Wake Lock API ویژگی killer را به وب بیاورید

هنگام آشپزی با دستگاه، هیچ چیز ناامیدکننده‌تر از این نیست که وقتی صفحه نمایش خاموش می‌شود، با دست‌های آشفته یا حتی بینی خود صفحه را لمس کنید. بتی کراکر از خود پرسید که چگونه می توانند ویژگی کشنده برنامه های iOS/Android خود را به برنامه وب منتقل کنند. این زمانی بود که آنها در مورد Project Fugu و Wake Lock API یاد گرفتند.

شخصی در حال ورز دادن خمیر روی میز آشپزخانه که با آرد پوشیده شده است

Wake Lock API راهی برای جلوگیری از تیره شدن یا قفل شدن صفحه نمایش دستگاه ارائه می دهد. این قابلیت تجربه‌های جدیدی را امکان‌پذیر می‌کند که تاکنون به یک برنامه iOS/Android نیاز داشتند. Wake Lock API نیاز به راه‌حل‌های هک و بالقوه پرقدرت را کاهش می‌دهد.

درخواست wake lock

برای درخواست wake lock، باید متد navigator.wakeLock.request() را فراخوانی کنید که یک شی WakeLockSentinel را برمی گرداند. شما از این شی به عنوان یک مقدار نگهبان استفاده خواهید کرد. مرورگر می تواند درخواست را به دلایل مختلف رد کند (مثلاً به دلیل کم بودن باتری)، بنابراین تمرین خوبی است که تماس را در یک عبارت try…catch قرار دهید.

آزاد کردن ویک لاک

شما همچنین به راهی برای آزاد کردن wake lock نیاز دارید که با فراخوانی متد release() شی WakeLockSentinel به دست می آید. اگر می‌خواهید پس از گذشت مدت زمان مشخصی wake lock را آزاد کنید، می‌توانید از window.setTimeout() برای فراخوانی release() استفاده کنید، همانطور که در مثال زیر نشان داده شده است.

// The wake lock sentinel.
let wakeLock
= null;

// Function that attempts to request a wake lock.
const requestWakeLock = async () => {
 
try {
    wakeLock
= await navigator.wakeLock.request('screen');
    wakeLock
.addEventListener('release', () => {
      console
.log('Wake Lock was released');
   
});
    console
.log('Wake Lock is active');
 
} catch (err) {
    console
.error(`${err.name}, ${err.message}`);
 
}
};

// Request a wake lock…
await requestWakeLock
();
// …and release it again after 5s.
window
.setTimeout(() => {
  wakeLock
.release();
  wakeLock
= null;
}, 5000);

پیاده سازی

با استفاده از برنامه وب جدید، کاربران باید بتوانند به راحتی در یک دستور غذا پیمایش کنند، مراحل کامل را طی کنند و حتی بدون قفل صفحه از آنجا دور شوند. برای دستیابی به این هدف، تیم ابتدا یک نمونه اولیه جلویی سریع به عنوان اثبات مفهوم و جمع‌آوری ورودی UX ساخت.

پس از اینکه نمونه اولیه مفید بود، آنها یک مؤلفه Vue.js طراحی کردند که می‌توانست در همه مارک‌هایشان ( بتی کراکر ، پیلزبری ، و قاشق غذاخوری ) به اشتراک گذاشته شود. اگرچه فقط بتی کراکر دارای برنامه‌های iOS و Android بود، اما این سه سایت دارای یک پایه کد مشترک هستند، بنابراین آنها می‌توانند یک بار مؤلفه را پیاده‌سازی کنند و آن را در همه جا مستقر کنند، همانطور که در تصاویر زیر نشان داده شده است.

تعویض قفل بیدار شدن BettyCrocker.com
تعویض قفل بیدار شدن BettyCrocker.com.
جابجایی قفل بیدار شدن Pillsbury.com
جابجایی قفل بیدار شدن Pillsbury.com.
جابجایی قفل Wake lock Tablespoon.com
جابجایی قفل Wake lock Tablespoon.com.

هنگام توسعه کامپوننت بر اساس چارچوب مدرن سایت جدید، تمرکز زیادی بر روی لایه ViewModel الگوی MVVM وجود داشت. این تیم همچنین با در نظر گرفتن قابلیت همکاری برنامه‌ریزی کرد تا عملکردهای قدیمی و چارچوب‌های جدید سایت را فعال کند.

برای پیگیری قابلیت مشاهده و قابلیت استفاده، Betty Crocker ردیابی تحلیلی را برای رویدادهای اصلی در چرخه حیات wake lock یکپارچه کرده است. این تیم از مدیریت ویژگی برای استقرار مولفه wake lock در یک سایت واحد برای عرضه اولیه تولید استفاده کرد و سپس این ویژگی را پس از نظارت بر استفاده و سلامت صفحه در بقیه سایت‌ها مستقر کرد. آنها به نظارت بر داده های تحلیلی بر اساس استفاده از این مؤلفه ادامه می دهند.

به عنوان یک ایمنی برای کاربران، تیم یک بازه زمانی اجباری ایجاد کرد تا پس از یک ساعت عدم فعالیت، wake lock را غیرفعال کند. اجرای نهایی آنها در کوتاه مدت یک سوئیچ تغییر روی تمام صفحات دستور غذا در سایت هایشان بود. در دراز مدت، آنها یک نمای صفحه دستور پخت اصلاح شده را تصور می کنند.

ظرف wake lock

var wakeLockControl = () => {
 
return import(/* webpackChunkName: 'wakeLock' */ './wakeLock');
};

export default {
  components
: {
    wakeLockControl
: wakeLockControl,
 
},
  data
() {
   
return {
      config
: {},
      wakeLockComponent
: '',
   
};
 
},
  methods
: {
    init
: function(config) {
     
this.config = config || {};
     
if ('wakeLock' in navigator && 'request' in navigator.wakeLock) {
       
this.wakeLockComponent = 'wakeLockControl';
     
} else {
        console
.log('Browser not supported');
     
}
   
},
 
},
};

جزء wake lock

<template>
 
<div class="wakeLock">
   
<div class="textAbove"></div>
   
<label class="switch" :aria-label="settingsInternal.textAbove">
     
<input type="checkbox" @change="onChange()" v-model="isChecked">
     
<span class="slider round"></span>
   
</label>
 
</div>
</template>

<script type="text/javascript">
 
import debounce from 'lodash.debounce';

 
const scrollDebounceMs = 1000;

 
export default {
    props
: {
      settings
: { type: Object },
   
},
    data
() {
     
return {
        settingsInternal
: this.settings || {},
        isChecked
: false,
        wakeLock
: null,
        timerId
: 0,
     
};
   
},
    created
() {
     
this.$_raiseAnalyticsEvent('Wake Lock Toggle Available');
   
},
    methods
: {
      onChange
: function() {
       
if (this.isChecked) {
         
this.$_requestWakeLock();
       
} else {
         
this.$_releaseWakeLock();
       
}
     
},
      $_requestWakeLock
: async function() {
       
try {
         
this.wakeLock = await navigator.wakeLock.request('screen');
         
//Start new timer
         
this.$_handleAbortTimer();
         
//Only add event listeners after wake lock is successfully enabled
          document
.addEventListener(
           
'visibilitychange',
           
this.$_handleVisibilityChange,
         
);
          window
.addEventListener(
           
'scroll',
            debounce
(this.$_handleAbortTimer, scrollDebounceMs),
         
);
         
this.$_raiseAnalyticsEvent('Wake Lock Toggle Enabled');
       
} catch (e) {
         
this.isChecked = false;
       
}
     
},
      $_releaseWakeLock
: function() {
       
try {
         
this.wakeLock.release();
         
this.wakeLock = null;
         
//Clear timer
         
this.$_handleAbortTimer();
         
//Clean up event listeners
          document
.removeEventListener(
           
'visibilitychange',
           
this.$_handleVisibilityChange,
         
);
          window
.removeEventListener(
           
'scroll',
            debounce
(this.$_handleAbortTimer, scrollDebounceMs),
         
);
       
} catch (e) {
          console
.log(`Wake Lock Release Error: ${e.name}, ${e.message}`);
       
}
     
},
      $_handleAbortTimer
: function() {
       
//If there is an existing timer then clear it and set to zero
       
if (this.timerId !== 0) {
          clearTimeout
(this.timerId);
         
this.timerId = 0;
       
}
       
//Start new timer; Will be triggered from toggle enabled or scroll event
       
if (this.isChecked) {
         
this.timerId = setTimeout(
           
this.$_releaseWakeLock,
           
this.settingsInternal.timeoutDurationMs,
         
);
       
}
     
},
      $_handleVisibilityChange
: function() {
       
//Handle navigating away from page/tab
       
if (this.isChecked) {
         
this.$_releaseWakeLock();
         
this.isChecked = false;
       
}
     
},
      $_raiseAnalyticsEvent
: function(eventType) {
        let eventParams
= {
         
EventType: eventType,
         
Position: window.location.pathname || '',
       
};
       
Analytics.raiseEvent(eventParams);
     
},
   
},
 
};
</script>

نتایج

مؤلفه Vue.js در هر سه سایت مستقر شده است و نتایج عالی ارائه می دهد. در طول دوره از 10 دسامبر 2019 تا 10 ژانویه 2020، BettyCrocker.com معیارهای زیر را گزارش کرد:

  • از بین تمام کاربران Betty Crocker با مرورگر سازگار با Wake Lock API، 3.5٪ از آنها بلافاصله این ویژگی را فعال کردند و آن را به یکی از 5 عمل برتر تبدیل کردند.
  • مدت جلسه برای کاربرانی که wake lock را فعال کردند 3.1× بیشتر از کاربرانی بود که این کار را انجام ندادند.
  • نرخ پرش برای کاربرانی که wake lock را فعال کرده بودند 50 درصد کمتر از کسانی بود که از ویژگی wake lock استفاده نمی کردند.
  • شاخص های قصد خرید برای کاربران wake lock در مقایسه با همه کاربران حدود 300 درصد بیشتر بود.

3.1 ×

مدت جلسه طولانی تر

50 درصد

نرخ پرش پایین تر

300 %

شاخص های قصد خرید بالاتر

نتیجه گیری

Betty Crocker با استفاده از Wake Lock API نتایج فوق العاده ای دیده است. می‌توانید این ویژگی را خودتان با جستجوی دستور غذای مورد علاقه‌تان در هر یک از سایت‌های آن‌ها ( BettyCrocker ، Pillsbury ، یا Tablespoon ) آزمایش کنید و گزینه «جلوگیری از تاریک شدن صفحه‌نمایش هنگام آشپزی» را فعال کنید.

موارد استفاده برای ویک قفل در سایت های دستور پخت متوقف نمی شود. نمونه‌های دیگر کارت پرواز یا برنامه‌های بلیط هستند که باید صفحه را تا زمانی که بارکد اسکن نشده است روشن نگه دارند، برنامه‌های کیوسکی که صفحه را به طور مداوم روشن نگه می‌دارند، یا برنامه‌های ارائه مبتنی بر وب که از خوابیدن صفحه در طول ارائه جلوگیری می‌کنند.

ما هر آنچه را که باید در مورد Wake Lock API بدانید را در مقاله ای جامع در همین سایت گردآوری کرده ایم. خواندن مبارک، و آشپزی شاد!

قدردانی

عکس شخص در حال ورز دادن خمیر توسط جولیان هوچگزانگ در Unsplash .