پرتال -اخبار و آگهی استخدام و دانشگاه

این سایت وابسته به هیچ سازمانی نیست

پرتال -اخبار و آگهی استخدام و دانشگاه

این سایت وابسته به هیچ سازمانی نیست

خطاهای بزرگ طراحی وب

خطاهای بزرگ طراحی وب

این مطلب بخشی از مقاله 10 اشتباه برتر طراحی وب نوشته دکتر جاکوب نیسلون است.



1- نامناسب بودن امکان جست‌وجو:

چه وقت به سراغ بخش جست‌وجوی سایت‌ها می‌روید؟ حتما زمانی که نتوانید به راحتی اطلاعات مورد نظرتان را پیدا کنید. کاربران هم از همین روش استفاده می‌کنند و هنگامی به سراغ بخش جستجوی سایت شما می‌روند که نتوانند از طریق راهنمای صفحه به اطلاعاتی که می‌خواهند دست پیدا کنند.



2- خوانندگان وب و فایل‌های pdf

خوانندگان وب از فایل‌های pdf دل خوشی ندارند. تصور کنید به‌ سختی مشغول جست‌وجو و گشت زدن در وب هستید که ناگهان به یک فایل pdf می‌رسید و فاجعه رخ می‌دهد؛ فشردگی خطوط، مشکلات نرم‌افزاری، از دست دادن فرصت جست‌وجو و گم کردن مسیر جستجو از مواردی است که فایل‌ PDF را کابوس خوانندگان وب می‌کند.

پس این شعار را فراموش نکنید: خداحافظ حروف و صفحه‌های چاپی و سلام فونت‌های لاغر و ریز.



3- تغییر نکردن رنگ لینک‌های دیده شده

برای کاربران آنلاین همیشه مهم است که چه لینکی را دیده‌اند؟ چه لینکی را می‌بیینند؟ و چه لینکی را می‌توانند ببینند.

لینک‌ها کلید اساسی راهنمایی فرد به مطلب مورد نظرش است. پس خیلی مهم است که تفاوت رنگ بین لینک‌های دیده شده و دیده نشده وجود داشته باشد.

فراموش نکنید آن‌ها انتظار دارند بدانند وقتی روی بخشی که لینک شده کلیک کردند به کجا می‌رود و چه مطلب و یا بخشی را می‌بینند.
دنیای www

4- متن‌هایی که قابل اسکن چشمی نباشند(درک شوندگی‌ در یک نگاه)

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

نوشتن برای وب و نوشتن برای رسانه‌های چاپی کاملا متفاوت است:

میان‌تیترها، بولت‌ها، کلید‌واژه‌های برجسته، پاراگراف‌های کوتاه، هرم وارونه، ساده نویسی و بی طمطراق و بدون بازاریابی نوشتن از نکاتی هستند که شما باید برای وب‌نویسی در نظر داشته باشید.[الگوی خواندن صفحات وب این است: F]



5- استفاده از فونت‌های ثابت

مشکل بیشتر وب سایت‌ها وجود فونت‌های ثابت است. فونت‌هایی لاغر و ریز که برای خیلی‌ها خوانا نیستند. آمار نشان می‌دهد که تا سال 2004 حدود 9 میلیون نفر با سن بالای 65 سال از اینترنت استفاده می‌کردند. پس چطور ‌می‌توانند فونت‌های ریز شما صفحه شما را بخوانند؟



6- عنوان صفحه

کاربران جدید بیشتر از طریق جست‌وجو در موتوهای جست‌وجو به سایت شما می‌رسند. عنوان صفحه که با تگ همراه هستند معمولا در نتایج صفحات جست‌وجو (SERP) قابل کیلک هستند. این موتوها معمولا تا 66 کارکتر اول عنوان صفحه را نشان می‌دهند.<br><br>فراموش نکنید که این عنوان صفحه است که در لیست سایت‌های محبوب کاربر(Favorites) ذخیره می‌شود. درضمن هیچگاه عنوان صفحه را با کلماتی مثل (the) یا (welcome to) شروع نکنید. این کار باعث می‌شود عنوان سایت شما به ناچار در زیر کلمات T و W در Favorites ذخیره شود.<br><br>عنوان سایت باید دقیقا با کلماتی شروع شود که هدف اصلی وب سایت شماست. کلماتی که کاربران در هنگام جست‌وجو از آن استفاده می‌کنند.<br><br>از طرف دیگر به کاربرانی فکر کنید که حرفه‌ای هستند و با چند پنجره مختلف کار می‌کنند. بنابراین سعی کنید که با کوتاه‌ترین کلمات عنوان سایت خودتان را نشان دهید تا در میان انبوه پنجره‌های کاربر راحت‌تر دیده شود.<br>خطاهای بزرگ طراحی وب<br><br>7- هر چیزی که شکل تبلیغات باشد<br><br>درنظر داشته باشید که کاربران وب معمولا هر چیزی که شکل تبلیغ دارد، رد می‌کنند و وقتی که کاربر پنجره‌ای را به این دلیل بست دیگر به جزییات آن پنجره فکر نمی‌کند.<br><br>بنابراین بهترین راه این است که از طراحی‌هایی که به شکل تبلیغات عرضه می‌شوند، دوری کنید.<br><br> دلایل محکمی برای این نظر وجود دارد:<br><br>• banner blindness: این بدان معناست که کاربران هرگز مسیر نگاهشان را بروی آگهی‌ها و یا حتی هر چیزی که شکل آن‌ها باشد نگه نمی‌دارند.<br><br>• animation avoidance: کاربران از هربخش چشمک زن و یا متن‌های فلش براحتی می‌گذرند<br><br>• pop-up purges: کاربران قبل از باز شدن کامل هر پنجره pop-up آن را می بندند. تازه اگر pop-up blocker نداشته باشند.<br><br> <br><br>8- حمله به طراحی پایدار<br><br>پایداری طراحی بزرگترین اصل در کاربردپذیری صفحات وب است. هنگامی که کاربران سایت شما از پایداری طراحی شما مطمئن باشند دیگر نگران این نیستند که چه اتفاقی در آینده می افتند چون آن‌ها می دانند چطور تجربه‌های جدید بروی وب سایت شما شکل می‌گیرد.<br><br> <br><br>9- باز شدن پنجره جدید<br><br>بازشدن پنجره جدید مثل کثیف کردن نمایشگر کاربر است. منصفانه نیست وقتی که طراحان از این روش برای حفظ کاربر بروی وب سایت خودشان استفاده می‌کنند.<br><br> شکست را قبول کنید و به جای این کار اجازه دهید اگر بروی لینک شما کلیک شد و چیز بدرد بخوری نداشتید بتوان با زدن دکمه برگشت به مسیر قبلی جست‌وجو برگشت. کاربران اصلا از این روش استقبال نمی‌کنند به خصوص اگر از نمایشگر‌های کوچک استفاده کنند بعد از چند کلیک بروی لینک‌های سایت شما دیگر نمی‌توانند به صفحه‌ای که از اول کلیک کرده بودند برگردند.<br><br>لینک‌ها باید درست در همان صفحه باز شوند. اگر فردی خواست که لینکی را در صفحه جدیدی ببیند می‌تواند از دستور open in new window در مرورگر خودش استفاده کند.<br><br> <br><br>10- جواب ندادن به سوال کاربر<br><br>هدف نهایی همه وب سایت ها کاربران هستند. آن‌ها برای دیدن وب سایت شما دلیل دارند. اما تعداد بی شماری از وب سایت‌ها به خوبی پاسخ کاربران خود را نمی‌دهند.<br><br>خیلی وقت‌ها جواب بسیار ساده است اما کاربر آن را پیدا نمی‌کند چون شما به درستی آن را عرضه نکردید. گاهی توضیحات خسته کننده و زیاد شما درباره محصولات، آن‌ها را از هدفشان دور می‌کند. آن‌ها خیلی وقت ندارند که بتوانند همه چیز را بخوانند.<br><br> <br><br>منبع: همشهری آنلاین<br><br>مطالب مرتبط:<br><br>بهینه سازی سایت برای جستجوگرها<br><br>چگونه برای وب بنویسیم<br><br>چگونه امتیاز سایت خودمان را در گوگل افزایش دهیم؟ (1) - (2)<br><br>اهمیت رنگ در طراحی وب<br><br>نـُه توصیه برای طراحان ایستگاه های اینترنتی </div> <div class="post-info pt-4 mt-3 d-flex flex-column flex-sm-row align-items-center"> <div class="author-info d-flex flex-column ml-auto"> <a href="/profile/6663598588" class="author-name">همیار جوان</a> <small class="post-date">1386/12/02 ساعت 01:40</small> </div> <div class="buttons-wrapper d-flex flex-row align-items-center mt-2 mt-md-0 mr-auto mr-md-0"> <span id="post-like-error-message-55" class="error-message alert alert-danger"></span> <button class="like-button btn btn-lg text-dark p-1" id="like-button" title="لایک مطلب" onclick="blogsky.ajax.postLike(this, event, 55);"> <span class="button-label" id="post-like-count-55">0</span> <span class="button-label">لایک</span> <i class="bx bx-heart text-dark"></i> </button> <script> blogsky.ajax.onPostLikeBegin = function (data) { var postLikeCountElement = document.getElementById("post-like-count-" + data.id); var postLikeCount = parseInt(postLikeCountElement.innerHTML); postLikeCountElement.innerHTML = postLikeCount + 1; } blogsky.ajax.onPostLikeSuccess = function () { document.getElementById("like-button").classList.add("active"); document.getElementById("like-button").querySelector(".bx").classList.replace("bx-heart", "bxs-heart"); } blogsky.ajax.onPostLikeFailure = function (data) { var postLikeCountElement = document.getElementById("post-like-count-" + data.id); postLikeCountElement.innerHTML = parseInt(postLikeCountElement.innerHTML) - 1; var postLikeErrorMessage = document.getElementById("post-like-error-message-" + data.id); postLikeErrorMessage.innerHTML = data.error; setTimeout(function () { postLikeErrorMessage.innerHTML = ""; }, 5000); } </script> </div> </div> </div> <div class="comments-box" id="comments"> <div class="comments-title d-flex align-items-center"> نظرات <span class="counter">0</span> <span class="flex-grow-1 mx-3" style="border-top: 1px solid rgba(87,89,90,.1);"></span> <a href="#comment-form-box" style="font-size: .75rem;">+ ارسال نظر</a> </div> <div id="comment-form-box" class="comment comment-form p-3 my-3"> <div id="comment-form"> <small id="gravatar-help" class="alert alert-secondary d-block text-center">برای نمایش آواتار خود در این وبلاگ در سایت <a rel="nofollow noopener" href="https://fa.gravatar.com/" target="_blank">Gravatar.com</a> ثبت نام کنید. (<a href="//www.blogsky.com/gravatar" target="_blank">راهنما</a>)</small> <div class="form-group row"> <label class="col-sm-3 col-form-label" for="bs-input-contact-name">نام</label> <div class="col-sm-9"> <input type="text" name="Name" id="bs-input-comment-name" class="bs-text-box bs-single-line" value="" /> </div> </div> <div class="form-group row"> <label class="col-sm-3 col-form-label" for="bs-input-contact-email">ایمیل</label> <div class="col-sm-9 text-left"> <input type="text" name="Email" id="bs-input-comment-email" class="bs-text-box bs-single-line bs-ltr" value="" /> </div> </div> <div class="form-group row"> <label class="col-sm-3 col-form-label" for="bs-input-contact-email">آدرس وبسایت</label> <div class="col-sm-9 text-left"> <input type="text" name="Website" id="bs-input-comment-website" class="bs-text-box bs-single-line bs-ltr" value="" placeholder="http(s)://" /> </div> </div> <div class="form-group row"> <label class="col-sm-3 col-form-label" for="bs-input-contact-message"></label> <div class="col-sm-9"> <textarea name="Comment" id="bs-input-comment-text" class="bs-text-box bs-multi-line"></textarea> <div class="emoji-box mt-2"> <img src="//www.blogsky.com/images/smileys/101.png" alt="" title="لبخند" onclick="insertCommentSmiley(':لبخند:')" /> <img src="//www.blogsky.com/images/smileys/102.png" alt="" title="چشمک" onclick="insertCommentSmiley(':چشمک:')" /> <img src="//www.blogsky.com/images/smileys/103.png" alt="" title="خجالت" onclick="insertCommentSmiley(':خجالت:')" /> <img src="//www.blogsky.com/images/smileys/104.png" alt="" title="ناراحت" onclick="insertCommentSmiley(':ناراحت:')" /> <img src="//www.blogsky.com/images/smileys/105.png" alt="" title="خوشتیپ" onclick="insertCommentSmiley(':خوشتیپ:')" /> <img src="//www.blogsky.com/images/smileys/106.png" alt="" title="عصبانی" onclick="insertCommentSmiley(':عصبانی:')" /> <img src="//www.blogsky.com/images/smileys/107.png" alt="" title="خنده" onclick="insertCommentSmiley(':خنده:')" /> <img src="//www.blogsky.com/images/smileys/108.png" alt="" title="زبان" onclick="insertCommentSmiley(':زبان:')" /> <img src="//www.blogsky.com/images/smileys/109.png" alt="" title="مسخره" onclick="insertCommentSmiley(':مسخره:')" /> <img src="//www.blogsky.com/images/smileys/110.png" alt="" title="کلافه" onclick="insertCommentSmiley(':کلافه:')" /> <img src="//www.blogsky.com/images/smileys/111.png" alt="" title="گریه" onclick="insertCommentSmiley(':گریه:')" /> <img src="//www.blogsky.com/images/smileys/112.png" alt="" title="پوزخند" onclick="insertCommentSmiley(':پوزخند:')" /> <img src="//www.blogsky.com/images/smileys/113.png" alt="" title="بدجنس" onclick="insertCommentSmiley(':بدجنس:')" /> <img src="//www.blogsky.com/images/smileys/114.png" alt="" title="تعجب" onclick="insertCommentSmiley(':تعجب:')" /> <img src="//www.blogsky.com/images/smileys/115.png" alt="" title="ناخوش" onclick="insertCommentSmiley(':ناخوش:')" /> <img src="//www.blogsky.com/images/smileys/116.png" alt="" title="بیخیال" onclick="insertCommentSmiley(':بیخیال:')" /> <img src="//www.blogsky.com/images/smileys/117.png" alt="" title="بوس" onclick="insertCommentSmiley(':بوس:')" /> <img src="//www.blogsky.com/images/smileys/118.png" alt="" title="خواب" onclick="insertCommentSmiley(':خواب:')" /> <img src="//www.blogsky.com/images/smileys/119.png" alt="" title="عاشق" onclick="insertCommentSmiley(':عاشق:')" /> <img src="//www.blogsky.com/images/smileys/120.png" alt="" title="راضی" onclick="insertCommentSmiley(':راضی:')" /> <img src="//www.blogsky.com/images/smileys/121.png" alt="" title="کسل" onclick="insertCommentSmiley(':کسل:')" /> <img src="//www.blogsky.com/images/smileys/122.png" alt="" title="نخبه" onclick="insertCommentSmiley(':نخبه:')" /> <img src="//www.blogsky.com/images/smileys/123.png" alt="" title="گل" onclick="insertCommentSmiley(':گل:')" /> <img src="//www.blogsky.com/images/smileys/124.png" alt="" title="هدیه" onclick="insertCommentSmiley(':هدیه:')" /> <img src="//www.blogsky.com/images/smileys/125.png" alt="" title="قلب" onclick="insertCommentSmiley(':قلب:')" /> <img src="//www.blogsky.com/images/smileys/126.png" alt="" title="نت" onclick="insertCommentSmiley(':نت:')" /> </div> </div> </div> <div class="form-group row"> <label for="" class="col-sm-3 col-form-label"></label> <div class="col-sm-9"> <div class="bs-captcha-box" id="bs-captcha-box"><script>var blogsky = blogsky || {}; blogsky.general = blogsky.general || {}; blogsky.general.refreshCaptcha = function () { var captchaImage = document.getElementById("bs-captcha-image"); captchaImage.src = captchaImage.src.substring(0, captchaImage.src.lastIndexOf("&") + 3) + Math.random(); }</script> <input autocomplete="off" class="bs-captcha-code form-control" data-val="true" data-val-required="وارد کردن کد امنیتی الزامی است." id="bs-captcha-code" maxlength="5" name="CaptchaCode" type="text" /> <img alt="" class="bs-captcha-image form-control-static" id="bs-captcha-image" src="/image/captcha?k=LM96EuIPw4dBLQfowc%2fYEbJTpIfVHIc29E1emJPVPDJwwGo%2fDY%2fUy8POhHkROfEqGYOHlqL53c4Z4istrvKdSlA9zk3HxxRh41KLj5cOXcJiBQr6&r=0.798984556365285" /> <div class="bs-captcha-refresh form-control-static btn btn-default" id="bs-captcha-refresh" onclick="blogsky.general.refreshCaptcha()" title="کد امنیتی جدید"></div> <input class="bs-captcha-key" id="bs-captcha-key" name="CaptchaKey" type="hidden" value="LM96EuIPw4dBLQfowc/YEbJTpIfVHIc29E1emJPVPDJwwGo/DY/Uy8POhHkROfEqGYOHlqL53c4Z4istrvKdSlA9zk3HxxRh41KLj5cOXcJiBQr6" /></div> </div> </div> <div class="form-group row"> <label for="" class="col-sm-3 col-form-label"></label> <div class="col-sm-9 check-box"> <input type="checkbox" name="SaveProfile" id="bs-input-comment-save-profile" class="bs-check-box" /> <label for="bs-input-comment-save-profile"> مشخصات مرا به خاطر بسپار </label> </div> </div> <div class="form-group row"> <label for="" class="col-sm-3 col-form-label"></label> <div class="col-sm-9" style="font-size: 0.875rem;"> ایمیل شما بعد از ثبت نمایش داده نخواهد شد </div> </div> <div id="comment-errors-message" class="message alert alert-danger"></div> <div class="form-group row justify-content-end mb-0"> <div class="col-sm-9"> <button type="submit" class="btn btn-primary" id="comment-submit-button" onclick="blogsky.ajax.commentSubmit(this, event, 55);">ارسال نظر</button> </div> </div> </div> </div> </div> <script> function insertCommentSmiley(smiley) { blogsky.general.insertAtCursor(document.getElementById("comments").getElementsByTagName("textarea")[0], smiley); } var commentInputs = document.getElementById("comment-form").getElementsByTagName("input"); for (var i = 0; i < commentInputs.length; i++) { commentInputs[i].addEventListener("keypress", function (event) { if (event.keyCode === 13) { document.getElementById("comment-submit-button").click(); var rect = document.getElementById("comment-submit-button").getBoundingClientRect(); if (rect.bottom > (window.innerHeight || document.documentElement.clientHeight)) { document.getElementById("comment-form-box").scrollIntoView(false); } } }); } blogsky.ajax.onCommentSubmitBegin = function () { document.getElementById("comment-submit-button").classList.add("loading"); document.getElementById("comment-submit-button").setAttribute("disabled", "disabled"); } blogsky.ajax.onCommentSubmitSuccess = function (data) { document.getElementById("comment-form").innerHTML = "<div class=\"message alert alert-danger mb-0\">" + data.data + "</div>"; window.location.href = window.location.href.split("#")[0] + "#comment-form-box"; } blogsky.ajax.onCommentSubmitFailure = function (data) { document.getElementById("comment-submit-button").classList.remove("loading"); document.getElementById("comment-submit-button").removeAttribute("disabled"); document.getElementById("comment-errors-message").innerHTML = data.error; } blogsky.ajax.onCommentRateBegin = function (data) { document.getElementById("comment-rate-plus-button-" + data.id).setAttribute("disabled", "disabled"); document.getElementById("comment-rate-minus-button-" + data.id).setAttribute("disabled", "disabled"); document.getElementById("comment-rate-wrapper-" + data.id).classList.add("loading"); switch (data.rateType) { case "plus": var commentRatePlus = document.getElementById("comment-rate-plus-count-" + data.id); commentRatePlus.innerHTML = parseInt(commentRatePlus.innerHTML) + 1; break; case "minus": var commentMinusPlus = document.getElementById("comment-rate-minus-count-" + data.id); commentMinusPlus.innerHTML = parseInt(commentMinusPlus.innerHTML) + 1; break; } } blogsky.ajax.onCommentRateFailure = function (data) { switch (data.rateType) { case "plus": var commentRatePlus = document.getElementById("comment-rate-plus-count-" + data.id); commentRatePlus.innerHTML = parseInt(commentRatePlus.innerHTML) - 1; break; case "minus": var commentMinusPlus = document.getElementById("comment-rate-minus-count-" + data.id); commentMinusPlus.innerHTML = parseInt(commentMinusPlus.innerHTML) - 1; break; } var commentRateErrorMessage = document.getElementById("comment-rate-error-message-" + data.id); commentRateErrorMessage.innerHTML = data.error; commentRateErrorMessage.style.display = "block"; setTimeout(function () { commentRateErrorMessage.style.display = "none"; }, 3000); } blogsky.ajax.onCommentRateComplete = function (data) { document.getElementById("comment-rate-plus-button-" + data.id).removeAttribute("disabled"); document.getElementById("comment-rate-minus-button-" + data.id).removeAttribute("disabled"); document.getElementById("comment-rate-wrapper-" + data.id).classList.remove("loading"); } </script> </div> </div> </div> <script> var sidebarButton = document.getElementById("sidebar-button"), sidebar = document.getElementById("sidebar"); sidebarButton.addEventListener("click", function (event) { event.stopPropagation(); document.body.setAttribute("data-scr", window.scrollY); document.body.style.top = "-" + window.scrollY + "px"; document.body.classList.add("menu-open"); sidebar.classList.add("reveal"); }) sidebar.addEventListener("click", function (event) { event.stopPropagation(); }) document.body.addEventListener("click", function () { if (document.body.classList.contains("menu-open")) { document.body.classList.remove("menu-open"); window.scrollTo(0, document.body.getAttribute("data-scr")); sidebar.classList.remove("reveal"); } }) blogsky.ajax.onPollVoteBegin = function (data) { document.getElementById("submit-vote-button-" + data.id).setAttribute("disabled", "disabled"); document.getElementById("submit-vote-button-" + data.id).classList.add("loading"); } blogsky.ajax.onPollVoteSuccess = function (data) { document.getElementById("poll-vote-" + data.id).innerHTML = data.data; } blogsky.ajax.onPollVoteFailure = function (data) { document.getElementById("submit-vote-button-" + data.id).removeAttribute("disabled"); document.getElementById("submit-vote-button-" + data.id).classList.remove("loading"); var pollVoteErrorMessage = document.getElementById("poll-vote-error-message-" + data.id); pollVoteErrorMessage.innerHTML = data.error; pollVoteErrorMessage.style.display = "block"; setTimeout(function () { pollVoteErrorMessage.style.display = "none"; }, 5000); } blogsky.ajax.onPollResultBegin = function (data) { document.getElementById("poll-results-button-" + data.id).setAttribute("disabled", "disabled"); document.getElementById("poll-results-button-" + data.id).classList.add("loading"); } blogsky.ajax.onPollResultSuccess = function (data) { document.getElementById("poll-vote-" + data.id).style.display = "none"; document.getElementById("poll-result-" + data.id).innerHTML = data.data; } blogsky.ajax.onPollResultFailure = function (data) { var pollVoteErrorMessage = document.getElementById("poll-vote-error-message-" + data.id); pollVoteErrorMessage.innerHTML = data.error; pollVoteErrorMessage.style.display = "block"; setTimeout(function () { pollVoteErrorMessage.style.display = "none"; }, 5000); } blogsky.ajax.onPollResultComplete = function (data) { document.getElementById("poll-results-button-" + data.id).removeAttribute("disabled"); document.getElementById("poll-results-button-" + data.id).classList.remove("loading"); } if (window.location.href.indexOf("/post-") > -1) { window.onscroll = function () { var articleElement = document.querySelector(".post-box"); var currentState = document.body.scrollTop || document.documentElement.scrollTop; var pageHeight = articleElement.scrollHeight; // var pageHeight = document.documentElement.scrollHeight - document.documentElement.clientHeight; var scrollStatePercentage = (currentState / pageHeight) * 100; document.querySelector(".reading-progress").setAttribute("value", scrollStatePercentage); if ((window.innerHeight + window.scrollY) >= document.body.offsetHeight) { document.querySelector(".reading-progress").setAttribute("value", 100); } } } if (document.getElementById("total-label")) { if (/^\/\d{4}\/\d{2}\/\d{2}\/post-\d+.*/i.test(window.location.pathname)) { document.getElementById("total-label").innerHTML = "نظر"; } else if (window.location.pathname.indexOf("/dailylink") == 0) { document.getElementById("total-label").innerHTML = "لینک"; } else if (window.location.search.indexOf("?q=") > -1) { document.getElementById("total-label").innerHTML = "نتیجه"; } else if (window.location.pathname == "" || window.location.pathname == "/" || window.location.pathname.indexOf("/page/") == 0 || window.location.pathname.indexOf("/posts") == 0 || window.location.pathname.indexOf("/category/") == 0 || window.location.pathname.indexOf("/tag/") == 0 || window.location.pathname.indexOf("/author/") == 0 || /^\/\d{4}(\/\d{2})?(\/\d{2})?/i.test(window.location.pathname)) { document.getElementById("total-label").innerHTML = "یادداشت"; } else { document.getElementById("total-label").innerHTML = "نظر"; } } //more (function (global, factory) { typeof exports === "object" && typeof module !== "undefined" ? module.exports = factory() : typeof define === "function" && define.amd ? define(factory) : (global = global || self, global.shave = factory()); }(this, function () { "use strict"; function shave(target, maxHeight) { var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; if (!maxHeight) throw Error("maxHeight is required"); var els = typeof target === "string" ? document.querySelectorAll(target) : target; if (!els) return; var character = opts.character || "…"; var classname = opts.classname || "js-shave"; var spaces = typeof opts.spaces === "boolean" ? opts.spaces : true; var charHtml = "<span class=\"js-shave-char\">".concat(character, "</span>"); if (!("length" in els)) els = [els]; for (var i = 0; i < els.length; i += 1) { var el = els[i]; var styles = el.style; var span = el.querySelector(".".concat(classname)); var textProp = el.textContent === undefined ? "innerText" : "textContent"; // If element text has already been shaved if (span) { el.removeChild(el.querySelector(".js-shave-char")); el[textProp] = el[textProp]; } var fullText = el[textProp]; var words = spaces ? fullText.split(" ") : fullText; if (words.length < 2) continue; var heightStyle = styles.height; styles.height = "auto"; var maxHeightStyle = styles.maxHeight; styles.maxHeight = "none"; if (el.offsetHeight <= maxHeight) { styles.height = heightStyle; styles.maxHeight = maxHeightStyle; continue; } var max = words.length - 1; var min = 0; var pivot = void 0; while (min < max) { pivot = min + max + 1 >> 1; el[textProp] = spaces ? words.slice(0, pivot).join(" ") : words.slice(0, pivot); el.insertAdjacentHTML("beforeend", charHtml); if (el.offsetHeight > maxHeight) max = spaces ? pivot - 1 : pivot - 2; else min = pivot; } el[textProp] = spaces ? words.slice(0, max).join(" ") : words.slice(0, max); el.insertAdjacentHTML("beforeend", charHtml); var diff = spaces ? " ".concat(words.slice(max).join(" ")) : words.slice(max); var shavedText = document.createTextNode(diff); var elWithShavedText = document.createElement("span"); elWithShavedText.classList.add(classname); elWithShavedText.style.display = "none"; elWithShavedText.appendChild(shavedText); el.insertAdjacentElement("beforeend", elWithShavedText); styles.height = heightStyle; styles.maxHeight = maxHeightStyle; } } return shave; })); shave(".collapsable", 25, { character: "<button class=\"btn btn-sm btn-link p-0 mr-1 d-inline\" style=\"cursor:pointer\"><small>ادامه...<small></button>" }); document.querySelector(".collapsable").addEventListener("click", function () { if (this.querySelector(".js-shave")) { this.querySelector(".js-shave-char").remove(); this.textContent += this.querySelector(".js-shave").textContent; } }); //Parallax (function (n, h) { "function" === typeof define && define.amd ? define([], h) : "object" === typeof module && module.exports ? module.exports = h() : n.Rellax = h() })("undefined" !== typeof window ? window : global, function () { var n = function (h, p) { var a = Object.create(n.prototype), l = 0, r = 0, k = 0, t = 0, c = [], u = !0, B = window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || window.msRequestAnimationFrame || window.oRequestAnimationFrame || function (a) { return setTimeout(a, 1E3 / 60) }, q = null, C = window.cancelAnimationFrame || window.mozCancelAnimationFrame || clearTimeout, D = window.transformProp || function () { var a = document.createElement("div"); if (null === a.style.transform) { var b = ["Webkit", "Moz", "ms"], e; for (e in b) if (void 0 !== a.style[b[e] + "Transform"]) return b[e] + "Transform" } return "transform" }(); a.options = { speed: -2, center: !1, wrapper: null, relativeToWrapper: !1, round: !0, vertical: !0, horizontal: !1, callback: function () { } }; p && Object.keys(p).forEach(function (d) { a.options[d] = p[d] }); h || (h = ".rellax"); var m = "string" === typeof h ? document.querySelectorAll(h) : [h]; if (0 < m.length) { a.elems = m; if (a.options.wrapper && !a.options.wrapper.nodeType) if (m = document.querySelector(a.options.wrapper)) a.options.wrapper = m; else { console.warn("Rellax: The wrapper you're trying to use doesn't exist."); return } var w = function () { for (var d = 0; d < c.length; d++)a.elems[d].style.cssText = c[d].style; c = []; r = window.innerHeight; t = window.innerWidth; x(); for (d = 0; d < a.elems.length; d++) { var b = a.elems[d], e = b.getAttribute("data-rellax-percentage"), g = b.getAttribute("data-rellax-speed"), h = b.getAttribute("data-rellax-zindex") || 0, l = b.getAttribute("data-rellax-min"), n = b.getAttribute("data-rellax-max"), v = a.options.wrapper ? a.options.wrapper.scrollTop : window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop; a.options.relativeToWrapper && (v = (window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop) - a.options.wrapper.offsetTop); var f = a.options.vertical ? e || a.options.center ? v : 0 : 0, k = a.options.horizontal ? e || a.options.center ? a.options.wrapper ? a.options.wrapper.scrollLeft : window.pageXOffset || document.documentElement.scrollLeft || document.body.scrollLeft : 0 : 0; v = f + b.getBoundingClientRect().top; var m = b.clientHeight || b.offsetHeight || b.scrollHeight, p = k + b.getBoundingClientRect().left, q = b.clientWidth || b.offsetWidth || b.scrollWidth; f = e ? e : (f - v + r) / (m + r); e = e ? e : (k - p + t) / (q + t); a.options.center && (f = e = .5); g = g ? g : a.options.speed; e = y(e, f, g); b = b.style.cssText; f = ""; 0 <= b.indexOf("transform") && (f = b.indexOf("transform"), f = b.slice(f), f = (k = f.indexOf(";")) ? " " + f.slice(11, k).replace(/\s/g, "") : " " + f.slice(11).replace(/\s/g, "")); c.push({ baseX: e.x, baseY: e.y, top: v, left: p, height: m, width: q, speed: g, style: b, transform: f, zindex: h, min: l, max: n }) } u && (window.addEventListener("resize", w), u = !1); z() }, x = function () { var d = l, b = k; l = a.options.wrapper ? a.options.wrapper.scrollTop : (document.documentElement || document.body.parentNode || document.body).scrollTop || window.pageYOffset; k = a.options.wrapper ? a.options.wrapper.scrollLeft : (document.documentElement || document.body.parentNode || document.body).scrollLeft || window.pageXOffset; a.options.relativeToWrapper && (l = ((document.documentElement || document.body.parentNode || document.body).scrollTop || window.pageYOffset) - a.options.wrapper.offsetTop); return d != l && a.options.vertical || b != k && a.options.horizontal ? !0 : !1 }, y = function (d, b, e) { var c = {}; d = 100 * e * (1 - d); b = 100 * e * (1 - b); c.x = a.options.round ? Math.round(d) : Math.round(100 * d) / 100; c.y = a.options.round ? Math.round(b) : Math.round(100 * b) / 100; return c }, A = function () { x() && !1 === u && z(); q = B(A) }, z = function () { for (var d, b = 0; b < a.elems.length; b++) { d = y((k - c[b].left + t) / (c[b].width + t), (l - c[b].top + r) / (c[b].height + r), c[b].speed); var e = d.y - c[b].baseY, g = d.x - c[b].baseX; null !== c[b].min && (a.options.vertical && !a.options.horizontal && (e = e <= c[b].min ? c[b].min : e), a.options.horizontal && !a.options.vertical && (g = g <= c[b].min ? c[b].min : g)); null !== c[b].max && (a.options.vertical && !a.options.horizontal && (e = e >= c[b].max ? c[b].max : e), a.options.horizontal && !a.options.vertical && (g = g >= c[b].max ? c[b].max : g)); a.elems[b].style[D] = "translate3d(" + (a.options.horizontal ? g : "0") + "px," + (a.options.vertical ? e : "0") + "px," + c[b].zindex + "px) " + c[b].transform } a.options.callback(d) }; a.destroy = function () { for (var d = 0; d < a.elems.length; d++)a.elems[d].style.cssText = c[d].style; u || (window.removeEventListener("resize", w), u = !0); C(q); q = null }; w(); A(); a.refresh = w; return a } console.warn("Rellax: The elements you're trying to select don't exist.") }; return n }); new Rellax(".rellax"); </script> </body> </html> <script> (function (i, s, o, g, r, a, m) { i['GoogleAnalyticsObject'] = r; i[r] = i[r] || function () { (i[r].q = i[r].q || []).push(arguments) }, i[r].l = 1 * new Date(); a = s.createElement(o), m = s.getElementsByTagName(o)[0]; a.async = 1; a.src = g; m.parentNode.insertBefore(a, m) })(window, document, 'script', '//www.google-analytics.com/analytics.js', 'ga'); ga('create', 'UA-40870092-3', 'auto'); ga('send', 'pageview'); </script>