آموزش ساخت ابزار محاسبه‌گر میزان ویتامین E و آنتی‌اکسیدان دریافتی در وب‌سایت.

ساخت

ساخت ابزار محاسبه ویتامین E و آنتی‌اکسیدان خشکبار: کدنویسی اکسیر جوانی (ریاضیاتِ زیبایی)

در دنیای تغذیه، همه کالری را می‌شمارند، اما حرفه‌ای‌ها “ریزمغذی‌ها” را می‌شمارند. ویتامین E حیاتی‌ترین ماده برای سلامت پوست و مو است و آنتی‌اکسیدان‌ها (که با واحد ORAC سنجیده می‌شوند) سربازان بدن در برابر پیری و بیماری هستند. جالب است بدانید که خشکبار (به‌ویژه گردو و تخمه آفتابگردان) غنی‌ترین منابع این دو ماده در جهان هستند.

ساخت ابزاری که به کاربر بگوید: “تبریک! معجون آجیلی شما معادل ۲ عدد کرم ضدچروک، ویتامین E دارد”، یک استراتژی گیمیفیکیشن عالی است که کاربر را عاشق سایت شما می‌کند.

در این آموزش، ما یک ماشین‌حساب دو منظوره می‌سازیم:

  1. سنجش ویتامین E: (بر حسب میلی‌گرم).

  2. سنجش قدرت آنتی‌اکسیدانی: (بر حسب واحد ORAC).


فاز ۱: پایگاه داده تغذیه‌ای (The Data Source)

برای این ابزار، ما به داده‌های دقیق آزمایشگاهی (معمولاً از USDA) نیاز داریم. مقادیر زیر برای ۱۰۰ گرم محصول است:

  1. تخمه آفتابگردان: ۳۵ میلی‌گرم ویتامین E (بمب ای!) | ۲۰۰۰ واحد ORAC.

  2. بادام درختی: ۲۶ میلی‌گرم ویتامین E | ۴۴۵۴ واحد ORAC.

  3. فندق: ۱۵ میلی‌گرم ویتامین E | ۹۶۴۵ واحد ORAC.

  4. گردو: ۰.۷ میلی‌گرم ویتامین E (کم) | ۱۳۵۴۱ واحد ORAC (بمب آنتی‌اکسیدان!).

  5. پکان (Pecan): ۱.۴ میلی‌گرم ویتامین E | ۱۷۹۴۰ واحد ORAC (رکورددار جهانی).

  6. پسته: ۲.۸ میلی‌گرم ویتامین E | ۷۶۷۵ واحد ORAC.

  • نیاز روزانه انسان به ویتامین E: حدود ۱۵ میلی‌گرم.

  • نیاز روزانه به آنتی‌اکسیدان (توصیه شده): حدود ۵۰۰۰ تا ۷۰۰۰ واحد ORAC.


فاز ۲: ساختار داده در جاوااسکریپت

JavaScript

const healthData = {
    "sunflower": { name: "تخمه آفتابگردان", e: 35.17, orac: 2000, color: "#fdd835" },
    "almond": { name: "بادام درختی", e: 25.63, orac: 4454, color: "#8d6e63" },
    "hazelnut": { name: "فندق", e: 15.03, orac: 9645, color: "#795548" },
    "pistachio": { name: "پسته", e: 2.86, orac: 7675, color: "#c5e1a5" },
    "walnut": { name: "گردو", e: 0.70, orac: 13541, color: "#6d4c41" },
    "pecan": { name: "پکان (گردو آمریکایی)", e: 1.40, orac: 17940, color: "#5d4037" }
};

const dailyGoals = { e: 15, orac: 7000 }; // اهداف روزانه

فاز ۳: رابط کاربری (HTML)

ما دو ستون (Bar Chart) می‌خواهیم: یکی برای ویتامین E (زیبایی) و یکی برای آنتی‌اکسیدان (ایمنی).

HTML

<div class="vitality-calc-box">
    <div class="calc-header-grad">
        <h3>💎 اکسیر جوانی و ایمنی</h3>
        <p>ببینید آجیل شما چقدر از پیری جلوگیری می‌کند!</p>
    </div>

    <div class="calc-inputs">
        <label>انتخاب مغز مغذی:</label>
        <select id="nut-type">
            <option value="sunflower">تخمه آفتابگردان (سلطان ویتامین E)</option>
            <option value="almond">بادام درختی</option>
            <option value="pecan">پکان (سلطان آنتی‌اکسیدان)</option>
            <option value="walnut">گردو</option>
            <option value="hazelnut">فندق</option>
            <option value="pistachio">پسته</option>
        </select>

        <label>مقدار مصرف (گرم):</label>
        <div class="input-row">
            <input type="number" id="nut-amount" value="30">
            <button onclick="calcVitality()" class="calc-btn">آنالیز کن ✨</button>
        </div>
    </div>

    <div id="result-panel" style="display:none;">
        
        <div class="metric-box">
            <div class="metric-title">
                <span>ویتامین E (سلامت پوست)</span>
                <span id="val-e">0 mg</span>
            </div>
            <div class="progress-bg">
                <div id="bar-e" class="progress-bar e-color">0%</div>
            </div>
            <p id="msg-e" class="mini-msg"></p>
        </div>

        <div class="metric-box">
            <div class="metric-title">
                <span>آنتی‌اکسیدان (قدرت ایمنی)</span>
                <span id="val-orac">0 ORAC</span>
            </div>
            <div class="progress-bg">
                <div id="bar-orac" class="progress-bar orac-color">0%</div>
            </div>
            <p id="msg-orac" class="mini-msg"></p>
        </div>

        <div class="final-verdict" id="verdict-text"></div>
    </div>
</div>

فاز ۴: استایل‌دهی (CSS)

ظاهری لوکس و سلامت‌محور با رنگ‌های بنفش (آنتی‌اکسیدان) و طلایی (ویتامین).

CSS

.vitality-calc-box {
    background: #fff; border-radius: 20px;
    box-shadow: 0 15px 40px rgba(103, 58, 183, 0.15);
    max-width: 480px; margin: 30px auto; overflow: hidden;
    font-family: 'Vazir', sans-serif; border: 1px solid #ede7f6;
}
.calc-header-grad {
    background: linear-gradient(135deg, #673ab7, #9575cd);
    color: white; padding: 25px; text-align: center;
}
.calc-header-grad h3 { margin: 0; font-size: 20px; }
.calc-header-grad p { margin: 5px 0 0; opacity: 0.9; font-size: 13px; }

.calc-inputs { padding: 25px; }
select, input {
    width: 100%; padding: 12px; margin: 8px 0 20px;
    border: 2px solid #eee; border-radius: 10px; font-size: 15px;
}
.input-row { display: flex; gap: 10px; }
.calc-btn {
    background: #ffca28; color: #333; border: none; padding: 12px 25px;
    border-radius: 10px; font-weight: bold; cursor: pointer; flex: 1;
    transition: 0.3s;
}
.calc-btn:hover { background: #ffb300; }

#result-panel { padding: 0 25px 25px; animation: slideUp 0.5s; }
.metric-box { margin-bottom: 20px; }
.metric-title { display: flex; justify-content: space-between; font-size: 14px; margin-bottom: 5px; color: #555; }
.progress-bg { background: #f0f0f0; height: 12px; border-radius: 6px; overflow: hidden; }
.progress-bar { height: 100%; width: 0%; transition: width 1s ease-out; border-radius: 6px; }

.e-color { background: linear-gradient(90deg, #ffca28, #ff6f00); } /* طلایی */
.orac-color { background: linear-gradient(90deg, #b39ddb, #673ab7); } /* بنفش */

.mini-msg { font-size: 11px; color: #777; margin-top: 5px; font-style: italic; }

.final-verdict {
    background: #ede7f6; color: #512da8; padding: 15px;
    border-radius: 12px; text-align: center; font-weight: bold; font-size: 14px;
    border: 1px dashed #b39ddb;
}

@keyframes slideUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }

فاز ۵: موتور محاسباتی (JavaScript)

JavaScript

<script>
function calcVitality() {
    // 1. دریافت ورودی
    const type = document.getElementById('nut-type').value;
    const weight = parseFloat(document.getElementById('nut-amount').value);
    
    if (!weight || weight <= 0) { alert("لطفاً وزن را وارد کنید"); return; }

    const data = healthData[type];

    // 2. محاسبات
    const intakeE = (data.e * weight) / 100;
    const intakeORAC = (data.orac * weight) / 100;

    // 3. درصد پیشرفت
    let pctE = (intakeE / dailyGoals.e) * 100;
    let pctORAC = (intakeORAC / dailyGoals.orac) * 100;

    // محدود کردن گرافیک به 100% (اگر بیشتر شد، سرریز نشود)
    const displayPctE = Math.min(pctE, 100);
    const displayPctORAC = Math.min(pctORAC, 100);

    // 4. نمایش در DOM
    document.getElementById('result-panel').style.display = 'block';
    
    // پر کردن بارها با تاخیر کم برای انیمیشن
    setTimeout(() => {
        document.getElementById('bar-e').style.width = displayPctE + "%";
        document.getElementById('bar-orac').style.width = displayPctORAC + "%";
    }, 100);

    // متن اعداد
    document.getElementById('val-e').innerText = intakeE.toFixed(1) + " mg";
    document.getElementById('val-orac').innerText = Math.round(intakeORAC) + " ORAC";

    // 5. پیام‌های هوشمند
    let msgE = "";
    if (pctE >= 100) msgE = "✨ عالی! نیاز روزانه پوست شما کاملاً تأمین شد.";
    else if (pctE >= 50) msgE = "👍 خوبه! نصف راه جوانی رو رفتی.";
    else msgE = "💡 نکته: برای پوست بهتر، تخمه آفتابگردان اضافه کن.";
    document.getElementById('msg-e').innerText = msgE;

    let msgORAC = "";
    if (pctORAC >= 100) msgORAC = "🛡️ فوق‌العاده! بدن شما ضدضربه شد.";
    else msgORAC = "💡 نکته: گردو یا پکان آنتی‌اکسیدان خیلی بیشتری دارند.";
    document.getElementById('msg-orac').innerText = msgORAC;

    // پیام نهایی ترکیبی
    const verdictBox = document.getElementById('verdict-text');
    if (type === 'sunflower') {
        verdictBox.innerHTML = "این انتخاب یعنی: <b>ضدچروک قوی</b> (به خاطر ویتامین E بالا).";
    } else if (type === 'walnut' || type === 'pecan') {
        verdictBox.innerHTML = "این انتخاب یعنی: <b>محافظت قوی در برابر بیماری</b> (آنتی‌اکسیدان بالا).";
    } else {
        verdictBox.innerHTML = "انتخابی متعادل برای سلامتی روزانه.";
    }
}
</script>

فاز ۶: استراتژی بازاریابی (Cross-Sell)

این ابزار به شما فرصت می‌دهد تا محصولات خاصی را بفروشید:

  1. اگر ویتامین E کم بود: وقتی کاربر “گردو” را انتخاب می‌کند، ویتامین E پایین است. پیام بدهید: “گردو برای مغز عالیه، اما برای پوستت کمه! پیشنهاد می‌کنیم مغز تخمه آفتابگردان هم به سبد خریدت اضافه کنی.”

  2. پک زیبایی: یک محصول تعریف کنید به نام “پک جوانسازی” (ترکیب تخمه و بادام) و لینک آن را زیر محاسبه‌گر بگذارید.


بخش پرسش و پاسخ فنی (FAQ)

۱. واحد ORAC دقیقاً چیست؟ ORAC مخفف Oxygen Radical Absorbance Capacity است. این یک استاندارد آزمایشگاهی برای اندازه‌گیری توانایی یک غذا در خنثی کردن رادیکال‌های آزاد (عامل سرطان و پیری) است. هرچه عدد بالاتر، بهتر.

۲. آیا پختن یا بودادن این اعداد را کم می‌کند؟ بله. ویتامین E به حرارت حساس است. در آجیل بوداده (Roasted)، حدود ۲۰ تا ۳۰ درصد ویتامین E از بین می‌رود. آنتی‌اکسیدان‌ها مقاوم‌ترند اما آن‌ها هم کاهش می‌یابند. بهتر است در توضیحات بنویسید: “این اعداد برای آجیل خام محاسبه شده‌اند.”

۳. چگونه این کد را در المنتور بگذارم؟ از ویجت HTML Code در المنتور استفاده کنید. کدهای HTML, CSS (داخل تگ style) و JS (داخل تگ script) را همه را پشت سر هم در همان ویجت کپی کنید. کار می‌کند!


جمع‌بندی: فروش علم به جای محصول

با ساخت این محاسبه‌گر ویتامین E و آنتی‌اکسیدان، شما سایت خشکبار را از یک “بقالی آنلاین” به یک “کلینیک زیبایی و سلامت” تبدیل می‌کنید. مشتری دیگر فقط ۳۰ گرم تخمه نمی‌خرد؛ او دارد “۵۰٪ از سلامت پوست امروزش” را می‌خرد. و این یعنی ارزش آفرینی واقعی.

🍑 طعم سلامتی با میوه‌های خشک AsanFruits

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

مشاهده محصولات میوه خشک

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *