۸ راه برای آسان سازی وردپرس
مهر ۲۴م, ۱۳۸۸
۸ راه برای اینکه وردپرس را برای مشتریانتان خوشایندتر کنید. اگر شما از وردپرس به عنوان یک CMS (سیستم مدیریت محتوا) برای ساخت وبگاه مشتریانتان استفاده کرده باشید، احتمالاً با این مشکل مواجه شدهاید: استفاده از وردپرس برای افراد عادی مشکل است. بله، محیط آن کاربر پسند است، ولی گویا نه به اندازه کافی برای کسانی که برای باز کردن پیوندها دوبار کلیک میکنند یا برای ورود به وبسایتها آدرس آنها را در گوگل وارد میکنند. برای آنکه نگهداری وبگاه توسط خود مشتریان را برایشان راحتتر کنید، از پیشنهادات زیر کمک بگیرید:
- نصب یک نسخه توسعه یافته از ویرایشگر پیشرفته
برای جلوگیری از پرسشهای مانند «فلان دکمه کجاست؟» این افزونه را نصب کنید. این افزونه یک صفحه تنظیمات نیز برای مدیریت دکمههای قابل نمایش در اختیارتان میگذارد. - افزودن ویرایشگر بصری برای ابزارکها
میدانید چه اتفاقی میافتد وقتی مشتری شما برای اولین بار سعی میکند تصویری را به سایدبار اضافه کند؟ با شما تماس میگیرد، غالبا آنهم زمانی که مشغول کاری بس مهمتر هستید. wordpress plugin to add rich-text widgets به محیط ویرایش متن ابزارکها، ویرایشگر بصری اضافه میکند. - مدیریت صفحات را آسانتر سازید
مدیریت صفحات در وردپرس برای کاربران عادی مشکل است. این افزونه واسط آسانی با قابلیت بکش و ولش (drag n drop) برای کاربران فراهم میکند. - به آنها امکان مدیریت ناوبری (navigation) بدهید
برای وبسایتهای کوچکتر چندان ضروری به نظر نمیرسد ولی اگر منوی راهبری و ناوبری شما ترکیبی از صفحات و شاخهها باشد، این افزونه امکان مدیریت آنها را در یک واسط کاربری آسان فراهم میکند. - اختیارات آنها را محدود کنید.
احتمالا، مشتریان شما از تعدادی از قابلیتهای وردپرس هرگز استفاده نمیکنند، پس چرا به آن دسترسی داشته باشند؟ Adminize میتواند سطح دسترسی به بخشهای مختلف محیط مدیریت را محدود کند. این به نوبه خود امکان خراب کردن و بهم ریختن محیط مدیریت را کاهش میدهد. - واسط کاربری محیط مدیریت را ساده کنید.
افزونه Admin Trim Interface میتواند واسط کاربری محیط مدیریت وردپرس را خلوتتر و در نتیجه امکان یافتن آنچه کاربران به دنبالش هستند را برای آنها ساده نماید. - به آنها امکان مدیریت فرمهای تماس را بدهید.
یکی از افزونههای زیر را امتحان کنید:- cforms II مدیریت آسانی دارد ولی اگر به این نکته اهمیت میدهید، امکان ارتقا خودکار ندارد.
- Contact Form 7
- به آنها امکان دسترسی به آمار را از درون محیط مدیریت بدهید
به این دلیل ساده: اکثر مشتریان به مدیریت چندین حساب کاربری برای سرویسهای مختلف آشنایی ندارند. افزونههای پیشنهادی:- Google Analyticator که سرویس Google Analytics را به محیط مدیریت میآورد.
- Feed stats آمار Feebburner را با محیط وردپرس مجتمع میکند.
آدرسهای تمیز
مهر ۲۴م, ۱۳۸۸
اهمیت داشتن URLهای تمیز نیازی به توضیح نداره، علاوه بر اینکه کاربران راحتتر اونها رو بهخاطر میسپارن و اهمیتش از نظر SEO، مشکلات آدرسهای پویا رو ندارند.
در پیادهسازی پروژه جدیدم از PHP خشک و خالی برای راهاندازی وبسایت استفاده کردم، بنابراین نیاز به راهی داشتم تا آدرسها رو تمیز کنم. دو قطعه کد htaccess فوقالعاده پیدا کردم ولی متاسفانه منبعشون رو یادداشت نکردم.
RewriteEngine On
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(.*)$ $1.php [L,QSA]
این، آدرسهای مشابه domain/about.php رو به domain/about تبدیل میکنه.
و،
RewriteEngine On
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(.*)$ index.php?q=$1 [L,QSA]
آدرسهای domain/index.php?q=about رو به domain/about
چطور استفاده کنم؟
در ریشه وبسایت یک فایل با نام .htaccess بسازید و اینها رو توشون کپی کنید یا اگه این فایل موجود بود اینها رو به اول فایل اضافه کنید.
بزن از جعبه بیرون!
مهر ۱۷م, ۱۳۸۸
ابتدا یه عذرخواهی بکنم از سالار عزیز، این نوشته به درخواست ایشون نوشته شد، منتهی خیلی دیر! نمیدونم چرا تازگیها خیلی بدقول شدم…
در این آموزش میخوایم جلوهای که در طراحی وب بسیار معمول شده رو پیاده کنیم. بیاید از جعبه بزنیم بیرون!
ابتدا باید جعبه و روبانمون رو طراحی کنیم. یه آموزش تصویری خوب در این رابطه رو در اینجا ببینید.
این آموزش هم نحوه ساخت روبانهایی با گوشههای نرم رو آموزش میده.
خوب، الان باید به فکر یه ساختار منطقی برای ارائه محتوا باشید. مثلاً این:
[html]
<div class="widget">
<h3>پیوندها</h3>
<ul>
<li><a href="#">Tween</a></li>
<li><a href="#">Tween</a></li>
<li><a href="#">Tween</a></li>
<li><a href="#">Tween</a></li>
<li><a href="#">Tween</a></li>
</ul>
</div>
[/html]
تصویر روبانمون رو به عنوان پسزمینه h3 معرفی میکنیم. تکنیک اینه که به h3مون position:relative بدیم. position:absolute و position:fixed عنصر رو از ساختار فعلی سند (جریان سند = documnt flow) خارج میکنن ولی با position:relative عنصر هنوز در همون موقعیت فعلیش میمونه و میتونیم شی رو نسبت به موقعیت فعلیش به میزان دلخواه جابهجا کنیم. این جابهجایی رو با top, right, bottom, left تعریف میکنیم. پس بهجز تعریفهای آرایشی، برای بهدست آوردن این جلوه به تعریفهای زیر نیاز داریم:
[css]
h3 {
width: 200px; /* به میزان دلخواه */
position: relative; /* مورد نیاز */
left: -30px; /* یعنی شی رو به میزان سی پیکسل به سمت چپ بکش */
background: url(images/ribbon.png) no-repeat; /* تصویر روبان */
}
[/css]
این width رو باید به اندازه (طول جعبه + اندازهای که میخوایم از دو طرفه بیرون بزنه) باید تعریف کنیم. دقت کنید که در css بالا ما مقدار right رو تعریف نکردیم. اگه میخوایم از سمت راست هم بیرون بزنه باید مقدار width رو زیاد کنیم و نباید right رو تعریف کنیم (از لحاظ منطقی هم اینکار معنایی نداره). اگه هم مقدار right و هم مقدار left رو تعریف کنیم مرورگر اگه در سند چپ به راست باشیم مقدار left و اگه سند راست به چپ باشه مقدار right رو استفاده میکنه و اون یکی رو در نظر نمیگیره. اگه هر دو مقدار top و bottom تعریف شده باشه مرورگر همیشه مقدار top رو استفاده میکنه.
درباره تفاوت انواع positionها اینجا رو بخونید: http://css-tricks.com/absolute-relative-fixed-positioining-how-do-they-differ/
یه استفاده معمول از position:relative برای تعریف position:absolute نسبت به یه عنصر دیگهست. توضیحات بیشتر رو در اینجا ببینید: http://css-tricks.com/absolute-positioning-inside-relative-positioning/
Ill never get it
مهر ۳م, ۱۳۸۸

برای طراحی یک وبسایت سرگرمی، عبارت joke رو در Google Images جستجو کردم تا به عکسی با عنوان Ill Never Get It رسیدم. ایدهی اولیه، ساخت قالبی است که بشود افقی پیمایشش کرد. منتهی این تصویر باید به پایین پنجره مرورگر میچسبید (پایین صفحه مرورگر صخره و بالا، آسمان). تکنیک استفاده شده به این صورت هست:
[html]
<div id="wrapper">
<div id="content">
<div class="content first">
</div>
<div class="content">
</div>
<div class="content">
</div>
<div class="content last">
</div>
</div> <!– #content –>
</div><!– #wrapper –>
[/html]
و شیوهنامه:
[css]
#wrapper {
position: absolute;
right: 0; bottom: 0;
height: 767px; width: 100%;
}
#content {
background: url(images/bg.png) repeat-x right center;
width: 4000px; height: 767px;
text-align: justify;
color: #d1c9a9;
}
[/css]
#wrapper با position:absolute و bottom:0 به پایین صفحه میچسبونیم. با width:100% طولش رو به اندازه عرض پنجره مرورگر تنظیم میکنیم. درون این یه div دیگه با شناسه #content هست. طول این با width: 4000px به اندازه مورد نیاز تنظیم شده و اون تصویر اولیه به عنوان تصویر پسزمینه به این یکی داده میشه. الان هم به پایین صفحه چسبیده و هم میشه افقی پیمایش کرد. این شیوه در هر سه مرورگر Opera, FF, IE بدون مشکل کار میکنه، در کروم (من از نسخه ۰٫۴ استفاده میکنم، شاید در نسخههای جدید اصلاح شده باشه) اگه تگ html خاصیت dir=rtl داشته باشه (یعنی سند راست به چپ باشه) خود نوار پیمایش حذف میشه ولی اگه چپ به راست باشه این مشکل وجود نداره.
من در اینجا برای تنظیم مکان جعبههایی که قراره محتوا رو نگهدارند (.content) از float استفاده کردم ولی میشه مکان اونها رو با position:absolute و یا relative در مکان دلخواه قرار داد.
تاملات
مهر ۳م, ۱۳۸۸
یاهو مدیا پلیر
شهریور ۳۰م, ۱۳۸۸
پریروز در Web Resources Depot معرفی مدیا پلیر یاهو رو دیدم. یه فایل جاوااسکریپتی که کاملاً مستقل عمل میکنه و به شما امکان میده یه پخشکننده صدای خیلی خوشکل توی سایتتون داشته باشید. تصمیم دارم از این در پروژهی که فعلاً مشغول کار برش هستم استفاده کنم، بنابراین بد ندیدم اینجا هم معرفیش کنم.
نحوه استفاده
نحوه استفاده به این صورت هست که ابتدا باید به فایلهای صوتی که میخواهید پخششون کنید لینک بدید. بعد باید فایل جاوااسکریپت رو به صفحه اضافه کنید:
[html]
<script type="text/javascript" src="http://mediaplayer.yahoo.com/js"></script>
[/html]
همین! این اسکریپت به طور خودکار لینکهای به فایلهای صوتی رو پیدا میکنه و یه دکمه پخش در کنار اونها قرار میده.
خود پخشکننده در گوشهی صفحه قرار میگیره بنابراین مزاحم بازدیدکننده نمیشه. رابط کاربری هم با فلش نیست و HTML هست بنابراین (اگرچه من امتحان نکردم) ولی باید بشه بهراحتی با CSS ظاهر رو دستکاری کرد.
خود اسکریپت بهرایگان در سایت یاهو میزبانی شده. مزایای این میزبانی مشابه میزبانی گوگل از کتابخانههای جاوااسکریپتیه. مطلبی از سایت Nano3oft با عنوان «جیکوئری سایت من را سنگین و کند میکند، نمیکند؟» این مزیتها رو شرح داده.
بیربط نوشت:
یه کانتستی بود اینجا، برنده ۲۵ دلار کوپن برای سایت Point Banners شدم، که همونطور که از اسمش مشخصه بنر طراحی میکنه. کسی نیاز به طراحی بنر نداره تا کوپن رو براش بفرستم؟
بازی جفتیابی
شهریور ۸م, ۱۳۸۸
گفتم جفتیابی یاد ارسطو افتادم. ارسطو معتقد بود در ابتدای جهان، زن و مرد یکی بودند و بسیار قدرتمند. خدایان که از وضع موجود میترسیدند انسان رو به دو نیمه زن و مرد تقسیم کردند و به این ترتیب قدرتش رو ازش گرفتند. ارسطو معتقد بود هر شخصی یه نیمه جدا افتاده از خودش داره و تنها با پیدا کردن اون شخص قدرت اولیهش رو بهدست میاره.
بازی جفتیابی رو معادل Matching Game در نظر گرفتم. (کسی معادل خوبی سراغ نداره؟) روند بازی بسیار سادهست: باید کارتهای مشابه همدیگه رو پیدا کرد. ابتدا یه چیزی بود برای تست تابع data در جیکوئری، بعد یه خورده آرایشش کردم تا شد این.
× رخداد مورد استفاده window.load هست چون در اینجا، باید قبل از اجرای کدها از لود شدن تصاویر اطمینان حاصل میشد.
× برای تصادفی کردن مکان تصاویر در DOM ابتدا نظرم این بود که عناصر رو در یه آرایه ذخیره کنیم، ترتیب عناصر آرایه رو به هم بریزیم و بعد دوباره تبدیل به عناصر دامش بکنیم. با جستجوی گوگل متوجه نوشته James در این رابطه و افزونه مفیدی که برای jQuery نوشته بود شدم. اون تابع shuffle از اونجا اومده.
× از متغیر stat برای ردگیری تعداد کلیکهای کاربر استفاده شده، با کلیک اول فقط کارت نمایش داده میشه و با کلیک دوم ارزیابی همانندی تصاویر و برنده شدن بازیکن انجام میشه.
× تصاویر مورد استفاده در بازی شکلهای پیشفرض فتوشاپ هستند.
باگهای شناخته شده:
کلیک چندین تصویر با فاصله زمانی کم موجب از کار افتادن بازی میشه. این به این دلیل هست که شرطهای کلیک دوم بعد از اجرای انیمیشن بالا اومدن تصویر اجرا میشن. اگه شرطها رو از اونجا خارج کنیم این مشکل حل میشه ولی خود تصویر چه حدس کاربر درست بوده باشه چه نه نمایش داده نمیشه (چون قبل از نمایش انیمیشن بالا اومدن تصویر اونها رو برمیگردونه سر جاشون)
در هر حال، همانطور که گفتم فقط برای تست چند تا تابع jQuery بود بنابراین همینجوری که هست ولش میکنم.
انیمیت خاصیتها
شهریور ۸م, ۱۳۸۸
امروز نوشتهای دیدم از James padolsey، اینجا: http://james.padolsey.com/javascript/fun-with-jquerys-animate/
به طور خلاصه گفته استفاده از تابع animate در jQuery محدود به پویاسازی خاصیتهای CSS نیست و میشه ازش برای تغییر مقدار مشخصهها (propery) در یک شی (در جاوااسکریپت اشیا به این صورت تعریف میشن: {propery: value} ) استفاده کرد.
مثال:
[js]
var from = {property: 0};
var to = {property: 100};
jQuery(from).animate(to, {
duration: 100,
step: function() {
console.log( ‘Currently @ ‘ + this.property );
}
});
[/js]
مثال گویای همهچیز هست ولی چند تا توضیح میدم: یه شی بینام به جیکوئری داده میشه و به عنوان اولین آرگومان تابع animate مقداری که باید به اونجا برسه (to) تعریف میشه. آرگومان بعدی تابع هم شی بینامیه که سایر تنظیمات تابع animate بهش داده میشه. اون duration:100 مقدار زمان به میلثانیهست و میشد اونو از این شی بینام خارج کرد و به عنوان آرگومان دوم به تابع داد. ترتیب آرگومانها در animate به یکی از این دو روشه:
[js]
/* #1 */
jQuery(’something’).animate({prop:1}, duration, easing, callback);
/* #2 */
jQuery(’something’).animate({prop:1},{
easing: easing,
duration: duration,
complete: callback
});
[/js]
با step یه تابع بینام بهش میدیم تا با هر بار تغییر مقدار فراخوانی بشه. در این تابع خود مقدار رو با یه رشته متنی به کنسول میفرستیم. دقت کنید که console.log فقط در فایرفاکس و با افزونه فایرباگ کار میکنه.
کارهایی که میشه با این انجام داد واقعاً نامحدوده (تنها عامل محدودهکننده تخیله). با این روش میشه هر چیزی رو به صورت انیمیشن درآورد.
هبوط
شهریور ۸م, ۱۳۸۸
[... از دیدگاه فیلیپ پلمن در نیروی اهریمنی اش هبوط نه تنها انسان را به دست رنج ها نسپرد در واقع دریچه ای به سوی آگاهی به روی او باز کرد و او را از زیر تسلط نامشروع ابرنیرو بر خودش آزاد کرد. به هر حال هم در خود جنوسیس یک چیزی مشابه همین می خونیم که خداوند به فرشتگانش [...] می فرماید:” الا بدانید که انسان که امروز تفاوت خیر و شر را می داند یکی از ما شده.” و در واقع مار وقتی حوا را به خوردن سیب ترغیب می کند می گوید:” این میوه دانش خداوندی بر تو عرضه می گرداند.” که شاید منظور پلمن نیز همین است…]
اینجا: http://www.fantasy.ir/fantasy/plugins/forum/forum_viewtopic.php?61529.0
بازی حدس اعداد
شهریور ۶م, ۱۳۸۸
امروز یه بازی فلش دیدم (اینجا) که به نظرم چیز جالبی اومد. بازی از این قراره: باید یه عدد دورقمی رو انتخاب کنید، اعداد سازندهی عدد رو با هم جمع کرده و از عدد اصلی کم کنید و بعد بازی یهسری شکل به شما نمایش میده که متناظر اعداد انتخابی شما هستند. نکته اینجا بود که در تمامی دفعات شکل انتخابی من درست نمایش داده شد. میبایست یه قاعده ریاضی پشت قضیه باشه. لجم گرفت ببینم چهطوری عمل میکنه و از اونجا که در محاسبات ذهنی خیلی ضعیفم، یه تکه کد جاوااسکریپت معما رو آشکار کرد:
[js]
for (i=10; i<100; i++) {
num = i – (parseFloat(i.toString().charAt(0)) + parseFloat(i.toString().charAt(1)));
$("#information").append(num+"<br/>");
}
[/js]
یک حلقه for که از ده تا ۹۹ میشماره. برای بهدست آوردن دو رقم انتخابی از متد charAt استفاده کردم ولی چون این متد تنها روی رشتهها کار میکنه، با toString عدد i رو به رشته تبدیل میکنه. و باز چون مقدار برگشتی رشته هست و نه عدد، عملگر + برای جمع دو مقدار کار نمیکنه بنابراین با تابع parseFloat کل عملیات رو دوباره به عدد تبدیل میکنیم. خط بعد فقط برای نمایش عدد محاسبه شده بود.
اعداد برگشتی همگی مضربی از ۹ هستند.
حقه جالبی بود. آفرین به سازندهش!
