<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Tween</title>
	<atom:link href="http://tween.ir/blog/feed/" rel="self" type="application/rss+xml" />
	<link>http://tween.ir/blog</link>
	<description>گاه‌نوشته‌های یک طراح وب</description>
	<lastBuildDate>Sun, 25 Jul 2010 08:41:27 +0000</lastBuildDate>
	<language>fa</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.0.1</generator>
		<item>
		<title>jqfundamentals</title>
		<link>http://tween.ir/blog/173/jqfundamentals/</link>
		<comments>http://tween.ir/blog/173/jqfundamentals/#comments</comments>
		<pubDate>Sun, 25 Jul 2010 08:40:47 +0000</pubDate>
		<dc:creator>tweener</dc:creator>
				<category><![CDATA[Cool Shit]]></category>
		<category><![CDATA[jQuery]]></category>

		<guid isPermaLink="false">http://tween.ir/blog/173/</guid>
		<description><![CDATA[Rebecca Murphey یکی از افرادیه که در پادکست yayQuery شرکت داره. این پادکست درباره جی‌کوئری و تحولات اون باضافه یه سری بخش‌های اضافه برای معرفی تکنیک‌های جی‌کوئری یا «پلاگین هفته»ست. به هر حال، در آخرین شماره این پادکست کتاب jQuery Fundamentals نوشته ایشون معرفی شد که اون طور که خودش گفت یه گردآوری از کدهای [...]]]></description>
			<content:encoded><![CDATA[<p>Rebecca Murphey یکی از افرادیه که در پادکست yayQuery شرکت داره. این پادکست درباره جی‌کوئری و تحولات اون باضافه یه سری بخش‌های اضافه برای معرفی تکنیک‌های جی‌کوئری یا «پلاگین هفته»ست. به هر حال، در آخرین شماره این پادکست کتاب jQuery Fundamentals نوشته ایشون معرفی شد که اون طور که خودش گفت یه گردآوری از کدهای نمونه و آموزش‌های مفید برای یاددهی جی‌کوئریه. یعنی برای آموزش دادن جی‌کوئری.<br />
من کتاب رو نخوندم، ولی «قرار بود» یه دوره کلاس آموزشی جی‌کوئری برگزار کنیم، که اگه کلاس تشکیل شد مطمئنا این کتاب مفید واقع خواهد شد.<br />
داشته باشیدش که کتاب پر از کده. اگه حوصله خوندن متن‌های طولانی رو برای یادگیری جی‌کوئری ندارید پیشنهاد می‌کنم کتاب رو بخونید: کدهای جی‌کوئری خیلی روان و ساده‌اند، بنابراین یادگیریش زمان نمی‌بره.<br />
راستی، وب‌سایت کتاب <a href="http://jqfundamentals.com/">jqfundamentals.com </a> هست.</p>
]]></content:encoded>
			<wfw:commentRss>http://tween.ir/blog/173/jqfundamentals/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>is_subpage</title>
		<link>http://tween.ir/blog/169/is_subpage/</link>
		<comments>http://tween.ir/blog/169/is_subpage/#comments</comments>
		<pubDate>Sun, 25 Jul 2010 08:28:02 +0000</pubDate>
		<dc:creator>tweener</dc:creator>
				<category><![CDATA[وردپرس]]></category>

		<guid isPermaLink="false">http://tween.ir/blog/169/</guid>
		<description><![CDATA[در وب‌سایت جدیدی که در حال ساخت هستم، هر یک از محصولات یک صفحه جداگانه در وردپرس دارند. یکی از این محصولات به دلیل تغییرات ظاهری نسبت به بقیه نیاز به قالبی جداگانه داشت. بنابراین برای این صفحه یک Page Template ساختم. مشکل این‌جاست که با افزودن یک صفحه به این سری محصول باز هم [...]]]></description>
			<content:encoded><![CDATA[<p>در وب‌سایت جدیدی که در حال ساخت هستم، هر یک از محصولات یک صفحه جداگانه در وردپرس دارند. یکی از این محصولات به دلیل تغییرات ظاهری نسبت به بقیه نیاز به قالبی جداگانه داشت. بنابراین برای این صفحه یک <a href="http://codex.wordpress.org/Pages#Creating_Your_Own_Page_Templates">Page Template </a> ساختم. مشکل این‌جاست که با افزودن یک صفحه به این سری محصول باز هم نیاز به انتخاب اون قالب هنگام انتشار صفحه‌ست که، در حالتی که بخوایم خود مشتری سایت‌شو مدیریت کنه اصلاً جالب نیست.<br />
راه حل استفاده از این تابع کوچولوئه:</p>
<pre><code>function is_subpage( $iID = null )
	{
		global $post, $wpdb;

		if ( is_page() AND isset( $post-&gt;post_parent ) != 0 )
		{
			$aParent = $wpdb-&gt;get_row( $wpdb-&gt;prepare( "SELECT ID FROM $wpdb-&gt;posts WHERE ID = %d AND post_type = 'page' LIMIT 1", $post-&gt;post_parent ) );

			if ( is_int( $iID ) &gt; 0 )
				if ( $aParent-&gt;ID == $iID ) return true; else return false;
			else
				if ( $aParent-&gt;ID )	return true; else return false;

		}
		else
		{
			return false;
		}
	}</code></pre>
<p>این تابع ID صفحه رو به عنوان آرگومان می‌گیره و چک می‌کنه که آیا صفحه فعلی ننه باباش فلان صفحه هست یا نه.<br />
می‌تونیم این کد رو توی page.php بذاریم و بر اون اساس تغییرات مورد نیازمون رو توی قالب ایجاد کنیم.<br />
نمونه استفاده:</p>
<pre><code>if ( is_subpage( 8 ) )
{
  //do something
};</code></pre>
<p>این تابع رو از وب‌سایت <a href="http://www.wprecipes.com">WP Recipes</a> گرفتم.</p>
<p>پانویس: از کاربران سیاره وردپرس فارسی پیشاپیش معذرت می‌خوام. فکر می‌کنم با انتشار این پست تمام نوشته‌های شاخه وردپرس‌ام دوباره منتشر بشند.</p>
]]></content:encoded>
			<wfw:commentRss>http://tween.ir/blog/169/is_subpage/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>مشکل مشکل</title>
		<link>http://tween.ir/blog/166/%d9%85%d8%b4%da%a9%d9%84-%d9%85%d8%b4%da%a9%d9%84/</link>
		<comments>http://tween.ir/blog/166/%d9%85%d8%b4%da%a9%d9%84-%d9%85%d8%b4%da%a9%d9%84/#comments</comments>
		<pubDate>Sat, 24 Jul 2010 06:54:44 +0000</pubDate>
		<dc:creator>tweener</dc:creator>
				<category><![CDATA[Uncategorized]]></category>

		<guid isPermaLink="false">http://tween.ir/blog/166/</guid>
		<description><![CDATA[علت انتشار چندین و چند باره‌ی پست‌های مربوط به وردپرس‌ام در سیاره وردپرس فارسی چیه؟ تا الان دو سه بار این طور شده.]]></description>
			<content:encoded><![CDATA[<p>علت انتشار چندین و چند باره‌ی پست‌های مربوط به وردپرس‌ام در سیاره وردپرس فارسی چیه؟ تا الان دو سه بار این طور شده.</p>
]]></content:encoded>
			<wfw:commentRss>http://tween.ir/blog/166/%d9%85%d8%b4%da%a9%d9%84-%d9%85%d8%b4%da%a9%d9%84/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>کشف دوباره جاوااسکریپت</title>
		<link>http://tween.ir/blog/163/%da%a9%d8%b4%d9%81-%d8%af%d9%88%d8%a8%d8%a7%d8%b1%d9%87-%d8%ac%d8%a7%d9%88%d8%a7%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa/</link>
		<comments>http://tween.ir/blog/163/%da%a9%d8%b4%d9%81-%d8%af%d9%88%d8%a8%d8%a7%d8%b1%d9%87-%d8%ac%d8%a7%d9%88%d8%a7%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa/#comments</comments>
		<pubDate>Thu, 22 Jul 2010 14:10:09 +0000</pubDate>
		<dc:creator>tweener</dc:creator>
				<category><![CDATA[Cool Shit]]></category>

		<guid isPermaLink="false">http://tween.ir/blog/163/</guid>
		<description><![CDATA[زمان آشنایی من با اینترنت برمی گرده به دوران Popupها، پنجره های لرزان مرورگر و وبلاگ هایی که برای ورود باید اسمتو وارد می کردی و هنگام خروج با نمایش یک alert اصرار داشتن که دوباره برگردی. بنابراین تعجبی نیست که خیلی سریع علاقه م رو به جی اس از دست دادم. در اون زمان [...]]]></description>
			<content:encoded><![CDATA[<p>زمان آشنایی من با اینترنت برمی گرده به دوران Popupها، پنجره های لرزان مرورگر و وبلاگ هایی که برای ورود باید اسمتو وارد می کردی و هنگام خروج با نمایش یک alert اصرار داشتن که دوباره برگردی. بنابراین تعجبی نیست که خیلی سریع علاقه م رو به جی اس از دست دادم. در اون زمان عملاً جاوااسکریپت مرده بود. ۲۰۰۵ و کشف ای جکس بود که جاوااسکریپت رو زنده کرد. ولی من بعد از اون هم به سراغ جی اس نرفتم. این بار دلیلش وجود کتابخونه های باحالی مثل jQuery بود.</p>
<p>چیزی که باعث شد شدیدا به جاوااسکریپت علاقه مند بشم دیدن ویدئوهای داگلاس کراکفورد در یاهو بود. مثل کشفی دوباره بود. جی اس اصلاً زبان بدی نیست. در واقع وقتی باهاش آشنا می‌شی متوجه می شی که فوق‌لعاده هم زبان خوبیه (نظر فعلی من؟ جی اس بهترین زبان برنامه نویسی موجوده) و بیشتر بدیش به خاطر شهرت بد و توسری خور بودنشه.</p>
<p>مثلاً یکی این که الان جاوااسکریپت تنها زبانیه که Prototype Based هست. جاوااسکریپت شی گراست. شی گراتر از هر زبان دیگه‌ای. (همه چیز در جاوااسکریپت شی ایه. حتی توابع) ولی هیچ کلاس پلاسی در این زبان وجود نداره.</p>
<p>من فعلاً سرم به مطالعه جاوااسکریپت گرمه ولی بعدها بیشتر راجع بهش صحبت می‌کنیم. فعلاً، برید ویدئوهای داگلاس کراکفورد در تئاتر یاهو رو ببینید:</p>
<p>آموزش جاواسکریپت، از اصول اولیه تا مباحث پیشرفته<br />
جلسه اول: JavaScript The Programming Language<br />
جلسه دوم: An Inconvenient API, The DOM Theory<br />
جلسه سوم: Advanced JavaScript<br />
این سه تا مال سال ۲۰۰۶ اند. جز جلسه سوم، همه مطالب رو به طور مفصل تر در جلساتی که امسال برگزار کرده توضیح داده.</p>
<p>Douglas Crockford on JavaScript<br />
<a href="http://developer.yahoo.com/yui/theater/video.php?v=crockonjs-1">جلسه اول</a> | <a href="http://developer.yahoo.com/yui/theater/video.php?v=crockonjs-2">جلسه دوم</a> | <a href="http://developer.yahoo.com/yui/theater/video.php?v=crockonjs-3">جلسه سوم</a> | <a href="http://developer.yahoo.com/yui/theater/video.php?v=crockonjs-4">جلسه چهارم</a> | <a href="http://developer.yahoo.com/yui/theater/video.php?v=crockonjs-5">جلسه پنجم</a><br />
جلسه اول این سری عملاً یک کلاس تاریخ تکنولوژیه، بنابراین برای علاقه مندان تاریخ توصیه می شه.</p>
<p><a href="http://developer.yahoo.com/yui/theater/video.php?v=crockford-json">The JSON Saga</a><br />
داستان JSON و چطوری شد که این طور شد.</p>
<p><a href="http://video.yahoo.com/video/play?vid=630959">JavaScript: The Good Parts</a><br />
چرا جاوااسکریپت زبان فوق العاده‌ایه؟</p>
<p>داگلاس کتابی هم به اسم JavaScript: The Good Parts نوشته. شدیداً توصیه می‌شه به خصوص که کل کتاب ۱۵۰ صفحه بیشتر نیست.</p>
]]></content:encoded>
			<wfw:commentRss>http://tween.ir/blog/163/%da%a9%d8%b4%d9%81-%d8%af%d9%88%d8%a8%d8%a7%d8%b1%d9%87-%d8%ac%d8%a7%d9%88%d8%a7%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>تئاتر یاهو</title>
		<link>http://tween.ir/blog/161/%d8%aa%d8%a6%d8%a7%d8%aa%d8%b1-%db%8c%d8%a7%d9%87%d9%88/</link>
		<comments>http://tween.ir/blog/161/%d8%aa%d8%a6%d8%a7%d8%aa%d8%b1-%db%8c%d8%a7%d9%87%d9%88/#comments</comments>
		<pubDate>Thu, 22 Jul 2010 14:02:19 +0000</pubDate>
		<dc:creator>tweener</dc:creator>
				<category><![CDATA[Cool Shit]]></category>

		<guid isPermaLink="false">http://tween.ir/blog/161/</guid>
		<description><![CDATA[الان حدود دو ساله که تئاتر یاهو رو دنبال می کنم. من اصولاً jQuery کارم، ولی سعی می کنم سرکی هم تو کتابخونه های دیگه بکشم؛ آشنایی با چندین کتابخانه به شما مزیت انتخاب می ده و این که بفهمید چرا باید این یا اونو استفاده کنید. مخصوصاً از YUI خیلی خوش میاد، یکی این‌که [...]]]></description>
			<content:encoded><![CDATA[<p>الان حدود دو ساله که تئاتر یاهو رو دنبال می کنم.  من اصولاً jQuery کارم، ولی سعی می کنم سرکی هم تو کتابخونه های دیگه بکشم؛ آشنایی با چندین کتابخانه به شما مزیت انتخاب می ده و این که بفهمید چرا باید این یا اونو استفاده کنید. مخصوصاً از YUI خیلی خوش میاد، یکی این‌که شرکت معظم یاهو پشت کتابخونه‌ست، از CDN یاهو قابل دسترسیه و در ضمن کلی ویدئوی آموزشی داره!</p>
<p>به هر حال، توصیه می کنم سری به تئاتر یاهو بزنید. بیشتر ویدئوها مربوط به کتابخونه YUI هستند ولی چیزهای خیلی خوبی راجع به Frontend Engineering توشون پیدا می شه.</p>
<p>توصیه می کنم اینا رو ببینید:<br />
<a href="http://video.yahoo.com/watch/4156174/11192533">Nicole Sullivan — Design Fast Websites</a><br />
<a href="http://developer.yahoo.com/yui/theater/video.php?v=heilmann-yql">Christian Heilmann — YQL and YUI: Building Blocks for Quick Applications</a><br />
<a href="http://video.yahoo.com/video/play?vid=1285664">Bill Scott — Designing the Rich Web Experience: Principles and Patterns for Rich Interaction Design on the Web</a><br />
<a href="http://video.yahoo.com/watch/4671445/12486762">Nate Koechley — Professional Frontend Engineering</a><br />
<a href="http://tween.ir/blog/163/%da%a9%d8%b4%d9%81-%d8%af%d9%88%d8%a8%d8%a7%d8%b1%d9%87-%d8%ac%d8%a7%d9%88%d8%a7%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa/">سری آموزش جاوااسکریپت از داگلاس کراکفورد</a></p>
]]></content:encoded>
			<wfw:commentRss>http://tween.ir/blog/161/%d8%aa%d8%a6%d8%a7%d8%aa%d8%b1-%db%8c%d8%a7%d9%87%d9%88/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>کتاب راهنمای ساخت افزونه برای فایرفاکس</title>
		<link>http://tween.ir/blog/159/%da%a9%d8%aa%d8%a7%d8%a8-%d8%b1%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d8%b3%d8%a7%d8%ae%d8%aa-%d8%a7%d9%81%d8%b2%d9%88%d9%86%d9%87-%d8%a8%d8%b1%d8%a7%db%8c-%d9%81%d8%a7%db%8c%d8%b1%d9%81%d8%a7%da%a9/</link>
		<comments>http://tween.ir/blog/159/%da%a9%d8%aa%d8%a7%d8%a8-%d8%b1%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d8%b3%d8%a7%d8%ae%d8%aa-%d8%a7%d9%81%d8%b2%d9%88%d9%86%d9%87-%d8%a8%d8%b1%d8%a7%db%8c-%d9%81%d8%a7%db%8c%d8%b1%d9%81%d8%a7%da%a9/#comments</comments>
		<pubDate>Thu, 22 Jul 2010 13:50:27 +0000</pubDate>
		<dc:creator>tweener</dc:creator>
				<category><![CDATA[XUL]]></category>

		<guid isPermaLink="false">http://tween.ir/blog/159/</guid>
		<description><![CDATA[شما را نمی دونم ولی من ترجیح می دم برای یادگیری یک موضوع یک کتابی رو بردارم و از اول تا تهش رو بخونم تا این که شروع کنم به مطالعه پراکنده راجع به اون موضوع. در حالت اول یه حس اطمینان وجود داره (که چیزی رو جا ننداختی)، و چون منسجم تر هست یادگیری [...]]]></description>
			<content:encoded><![CDATA[<p>شما را نمی دونم ولی من ترجیح می دم برای یادگیری یک موضوع یک کتابی رو بردارم و از اول تا تهش رو بخونم تا این که شروع کنم به مطالعه پراکنده راجع به اون موضوع. در حالت اول یه حس اطمینان وجود داره (که چیزی رو جا ننداختی)، و چون منسجم تر هست یادگیری هم ساده تره.</p>
<p>مدت ها بود دلم می خواست XUL («زول» تلفظ می شه) رو یاد بگیرم. خیلی ساده XUL یه زبان مارک آپ مبتنی بر XML برای ساخت اینترفیس هست. موزیلا این رو توسعه داد تا ازش در ساخت فایرفاکس استفاده کنه. در واقع تکنولوژی پشت افزونه های فایرفاکس همین XUL هست. برای کدنویسی هم از جاوااسکریپت استفاده می شه. ولی من اصلاً به ساخت افزونه برای فایرفاکس علاقه مند نیستم (چون نیازی هم بهش ندارم). موزیلا نرم افزاری رو توسعه داد به نام XUL Runner که می شه ازش برای ساخت برنامه تحت سه سیستم عامل با XUL برنامه ساخت.</p>
<p>کاربرد XUL به همین جا ختم نمی شه. مثلاً مدتی قبل Site Fusion معرفی شد که برای ساخت اینترفیس برنامه از همین زول استفاده می کنه (توضیحات بیشتر رو <a href="http://blog.itnotes.info/archives/394">این جا</a> بخونید)</p>
<p>حالا اگه علاقه مندید زول رو یاد بگیرید کتاب <a href="http://www.sitepoint.com/books/byofirefoxpdf1/">Build Your Own FireFox Extension </a> رو از SitePoint رو بگیرید. SitePoint به مناسبت انتشار افزونه CodeBurnerاش (یه افزونه که به فایرباگ می چسبه و مرجع HTML و CSS هست) کتاب رو به رایگان برای دانلود گذاشته. کتاب ۷۰ صفحه بیشتر نیست و خیلی هم خوب نوشته شده. بگیریدش که از دست نره.</p>
]]></content:encoded>
			<wfw:commentRss>http://tween.ir/blog/159/%da%a9%d8%aa%d8%a7%d8%a8-%d8%b1%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d8%b3%d8%a7%d8%ae%d8%aa-%d8%a7%d9%81%d8%b2%d9%88%d9%86%d9%87-%d8%a8%d8%b1%d8%a7%db%8c-%d9%81%d8%a7%db%8c%d8%b1%d9%81%d8%a7%da%a9/feed/</wfw:commentRss>
		<slash:comments>5</slash:comments>
		</item>
		<item>
		<title>حل مشکل چپ و راستی محیط مدیریت</title>
		<link>http://tween.ir/blog/157/%d8%ad%d9%84-%d9%85%d8%b4%da%a9%d9%84-%da%86%d9%be-%d9%88-%d8%b1%d8%a7%d8%b3%d8%aa%db%8c-%d9%85%d8%ad%db%8c%d8%b7-%d9%85%d8%af%db%8c%d8%b1%db%8c%d8%aa/</link>
		<comments>http://tween.ir/blog/157/%d8%ad%d9%84-%d9%85%d8%b4%da%a9%d9%84-%da%86%d9%be-%d9%88-%d8%b1%d8%a7%d8%b3%d8%aa%db%8c-%d9%85%d8%ad%db%8c%d8%b7-%d9%85%d8%af%db%8c%d8%b1%db%8c%d8%aa/#comments</comments>
		<pubDate>Thu, 22 Jul 2010 13:45:10 +0000</pubDate>
		<dc:creator>tweener</dc:creator>
				<category><![CDATA[وردپرس]]></category>

		<guid isPermaLink="false">http://tween.ir/blog/157/</guid>
		<description><![CDATA[برای راه اندازی سایتی چند زبانه که با وردپرس راه اندازی شده بود از WPML استفاده کردم. باید بگم این افزونه بهترین افزونه برای ساخت سایت چندزبانه بوده که تا حالا در هر سیستمی دیدم. تنها مشکلش اینه که با فعال کردنش محیط مدیریت رو می کنه از چپ به راست. در واقع مانع بارگذاری [...]]]></description>
			<content:encoded><![CDATA[<p>برای راه اندازی سایتی چند زبانه که با وردپرس راه اندازی شده بود از WPML استفاده کردم. باید بگم این افزونه بهترین افزونه برای ساخت سایت چندزبانه بوده که تا حالا در هر سیستمی دیدم. تنها مشکلش اینه که با فعال کردنش محیط مدیریت رو می کنه از چپ به راست. در واقع مانع بارگذاری شیوه نامه راست به چپ می شه که یعنی فونت های محیط مدیریت هم به هم می ریزن.</p>
<p>با نگاه به سورس صفحه متوجه شدم که در محیط مدیریت فایل wp-admin/load-style.php با پارامتر dir=ltr فراخوانی شده. بنابراین باید وردپرس رو وادار کنیم dir=rtl باشه.</p>
<p>راه من خیلی تخمیه. ولی کار می کنه. فایل load-style.php رو که باز می کنیم در حول و حوش خط ۱۲۸ یه همچین چیزی می بینیم:<br />
(من از وردپرس ۳٫۰ استفاده می کنم)</p>
<pre><code>	if ( $rtl &amp;&amp; isset($style-&gt;extra['rtl']) &amp;&amp; $style-&gt;extra['rtl'] ) {
		$rtl_path = is_bool($style-&gt;extra['rtl']) ? str_replace( '.css', '-rtl.css', $path ) : ABSPATH . $style-&gt;extra['rtl'];
		$content .= get_file($rtl_path) . "\n";
	}
</code></pre>
<p>تنها کاری که من کردم برداشتن شرط بود تا همیشه الحاق فایل rtl انجام بشه.<br />
این ایده خیلی بدیه. پس فردا که آپدیت کردیم این تغییرات می پره. معمولاً در این مواقع از API وردپس برای فیلتر کردن توابع استفاده می کنند تا مجبور به ویرایش مستقیم فایل های وردپرس نشند ولی مشکل این جاست که این تکه کد درون هیچ تابعی نیست!<br />
به هر حال، من آدم تنبلیم، حوصله جستجو برای راه حلو ندارم! همین برداشتن شرط (فعلاً) کار می کنه.</p>
]]></content:encoded>
			<wfw:commentRss>http://tween.ir/blog/157/%d8%ad%d9%84-%d9%85%d8%b4%da%a9%d9%84-%da%86%d9%be-%d9%88-%d8%b1%d8%a7%d8%b3%d8%aa%db%8c-%d9%85%d8%ad%db%8c%d8%b7-%d9%85%d8%af%db%8c%d8%b1%db%8c%d8%aa/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>درباره CommonJS</title>
		<link>http://tween.ir/blog/155/%d8%af%d8%b1%d8%a8%d8%a7%d8%b1%d9%87-commonjs/</link>
		<comments>http://tween.ir/blog/155/%d8%af%d8%b1%d8%a8%d8%a7%d8%b1%d9%87-commonjs/#comments</comments>
		<pubDate>Sun, 20 Jun 2010 07:17:53 +0000</pubDate>
		<dc:creator>tweener</dc:creator>
				<category><![CDATA[Uncategorized]]></category>

		<guid isPermaLink="false">http://tween.ir/blog/?p=155</guid>
		<description><![CDATA[این جا را بخوانید تا باز در این رابطه با هم صحبت کنیم: http://arstechnica.com/web/news/2009/12/commonjs-effort-sets-javascript-on-path-for-world-domination.ars]]></description>
			<content:encoded><![CDATA[<p>این جا را بخوانید تا باز در این رابطه با هم صحبت کنیم: <a href="http://arstechnica.com/web/news/2009/12/commonjs-effort-sets-javascript-on-path-for-world-domination.ars">http://arstechnica.com/web/news/2009/12/commonjs-effort-sets-javascript-on-path-for-world-domination.ars</a></p>
]]></content:encoded>
			<wfw:commentRss>http://tween.ir/blog/155/%d8%af%d8%b1%d8%a8%d8%a7%d8%b1%d9%87-commonjs/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>پراکنده درباره IE</title>
		<link>http://tween.ir/blog/153/%d9%be%d8%b1%d8%a7%da%a9%d9%86%d8%af%d9%87-%d8%af%d8%b1%d8%a8%d8%a7%d8%b1%d9%87-ie/</link>
		<comments>http://tween.ir/blog/153/%d9%be%d8%b1%d8%a7%da%a9%d9%86%d8%af%d9%87-%d8%af%d8%b1%d8%a8%d8%a7%d8%b1%d9%87-ie/#comments</comments>
		<pubDate>Thu, 10 Jun 2010 22:34:28 +0000</pubDate>
		<dc:creator>tweener</dc:creator>
				<category><![CDATA[Uncategorized]]></category>

		<guid isPermaLink="false">http://tween.ir/blog/?p=153</guid>
		<description><![CDATA[یک. یه اسکریپت هست برای پشتیبانی از Border-Radius در همه نسخه های IE. فقط باید این رو به فایل CSSتون اضافه کنید: .round { behaviour: url('path/to/border-radius.htc'); } دستور BEHAVIOUR رو تنها IE پشتیبانی می کنه و الباقی مرورگرها ندید می گیرندش. نحوه کارش به این صورت هست که فایل استایل تون رو برای دستورات border-radius [...]]]></description>
			<content:encoded><![CDATA[<p>یک. یه اسکریپت هست برای پشتیبانی از Border-Radius در همه نسخه های IE. فقط باید این رو به فایل CSSتون اضافه کنید:</p>
<pre><code>.round {
behaviour: url('path/to/border-radius.htc');
}</code></pre>
<p>دستور BEHAVIOUR رو تنها IE پشتیبانی می کنه و الباقی مرورگرها ندید می گیرندش.<br />
نحوه کارش به این صورت هست که فایل استایل تون رو برای دستورات border-radius با هر prefixای که زده باشید بررسی می کنه و این گوشه گردی رو به اون عناصر اضافه می کنه.<br />
از این جا بگیریدش: <a href="http://code.google.com/p/curved-corner/">http://code.google.com/p/curved-corner/</a></p>
<p>دو. تکنیکی هست برای پشتیبانی از RGBA در IE. با فیلتر گرادینت که آشنایید؟ کافیه طیف رنگی که هر دو رنگ مبدا و مقصدش یکی باشند تعریف کنید. چیزی که حتی در مستندات خود مایکروسافت نیومده اینه که این فیلتر از  کانال آلفا هم پشتیبانی می کنه. تعریفش به این صورته:</p>
<pre><code>.element {
	background:none;
	-ms-filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#CC000000,endColorstr=#CC000000);
	filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#CC000000,endColorstr=#CC000000);
	/* #CC000000 is rgba(0,0,0,.80) */
	zoom: 1; /* make sure element has hasLayout */
	position: relative; /* is needed to enable clearType when using filters */
}</code></pre>
<p>ابتدا پس زمینه رو که قبلاً برای مرورگرهای دیگه و با استفاده از RGBA تعریف کردیم رو حذف می کنیم. بعد فیلتر طیف رنگی رو می سازیم. توجه کنید که رنگ های تعریف شده به فرمت هگز و به صورت ARGB هستند.<br />
فیلتر دو بار تعریف شده، یه بار با پیشوند ms که برای مرورگرهای IE8 به بالاست و یه بار بدون پیشوند برای نسخه های ۷ به پایین. اون zoom: 1 هم برای این تعریف شده تا به عنصر خاصیت hasLayout بده. کلاً چیز مهمی نیست.<br />
حالا، استفاده از فیلترها باعث می شه clearType برای اون عناصر غیرفعال بشه، نتیجتاً متون واضح و شفاف نمایش داده نمی شن. برای دوباره فعالیدن این خاصیت باید مقدار position: relative رو به عنصر داد.<br />
واضحه که این دستورات رو باید با تکنیک دلخواه فقط برای IE فعال کرد.<br />
برای تبدیل RGBA به مقدار مشابهش با فرمت هگز و به صورت ARGB، این جا رو ببینید: http://kilianvalkhof.com/2010/css-xhtml/how-to-use-rgba-in-ie/<br />
همین. سخت بود؟!</p>
<p>سه. از شیوه نامه های مخصوص IE که با تکنیک Conditional Comment (توضیحات شرطی) ساخته می شن استفاده نکنید!<br />
اینجا: <a href="http://www.phpied.com/conditional-comments-block-downloads/"> http://www.phpied.com/conditional-comments-block-downloads/</a><br />
توضیح داده که تعریف شیوه نامه مخصوص IE حتی وقتی اون شیوه نامه برای اون نسخه از IE نباشه باز هم بارگذاری الباقی صفحه رو بلاک می کنه که باعث کند شدن رندر صفحه می شه. این هم از باگ های عجیب IE.</p>
<p>چهار. برای تست طراحی روی نسخه های مختلف IE، پیشنهاد می کنم IE Collection رو امتحان کنید. همراه این شما IE Developer Toolbar رو هم دریافت می کنید، مشابه افزونه Developer Toolbar در فایرفاکس.</p>
]]></content:encoded>
			<wfw:commentRss>http://tween.ir/blog/153/%d9%be%d8%b1%d8%a7%da%a9%d9%86%d8%af%d9%87-%d8%af%d8%b1%d8%a8%d8%a7%d8%b1%d9%87-ie/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>CCS3 و مشکلات پشتیبانی مرورگرها</title>
		<link>http://tween.ir/blog/150/ccs3-%d9%88-%d9%85%d8%b4%da%a9%d9%84%d8%a7%d8%aa-%d9%be%d8%b4%d8%aa%db%8c%d8%a8%d8%a7%d9%86%db%8c-%d9%85%d8%b1%d9%88%d8%b1%da%af%d8%b1%d9%87%d8%a7/</link>
		<comments>http://tween.ir/blog/150/ccs3-%d9%88-%d9%85%d8%b4%da%a9%d9%84%d8%a7%d8%aa-%d9%be%d8%b4%d8%aa%db%8c%d8%a8%d8%a7%d9%86%db%8c-%d9%85%d8%b1%d9%88%d8%b1%da%af%d8%b1%d9%87%d8%a7/#comments</comments>
		<pubDate>Thu, 10 Jun 2010 13:41:45 +0000</pubDate>
		<dc:creator>tweener</dc:creator>
				<category><![CDATA[Uncategorized]]></category>

		<guid isPermaLink="false">http://tween.ir/blog/150/ccs3-%d9%88-%d9%85%d8%b4%da%a9%d9%84%d8%a7%d8%aa-%d9%be%d8%b4%d8%aa%db%8c%d8%a8%d8%a7%d9%86%db%8c-%d9%85%d8%b1%d9%88%d8%b1%da%af%d8%b1%d9%87%d8%a7/</guid>
		<description><![CDATA[اغلب دستورات اضافه شده مثل Box Shadow، GRBA، Gradients، و&#8230; به CSS3، امکان تعیین fallback رو دارند. مثلاً برای RGBA می شه این طور نوشت که: background: #000000; background: rgba(0,0,0,0.75); و مرورگرهایی که از RGBA پشتیبانی می کنند دومی رو استفاده می کنند. اگر نه هم که بود و نبودشون به تجربه کاربری لطمه نمی [...]]]></description>
			<content:encoded><![CDATA[<p>اغلب دستورات اضافه شده مثل Box Shadow، GRBA، Gradients، و&#8230; به CSS3، امکان تعیین fallback رو دارند. مثلاً برای RGBA می شه این طور نوشت که:<br />
<code>background: #000000;<br />
background: rgba(0,0,0,0.75);</code><br />
و مرورگرهایی که از RGBA پشتیبانی می کنند دومی رو استفاده می کنند. اگر نه هم که بود و نبودشون به تجربه کاربری لطمه نمی زنه، مثل border-radius یا box-shadow. خیلی هم خوب. اما زمانی هست که مشتریان شما اصرار دارند طراحی در همه مرورگرها کاملاً یکسان نمایش داده بشه. خب، برای همون مثال RGBA، کد بالا رو به این صورت تغییر می دیم:<br />
<code>background: url(images/tran-black.png) repeat;<br />
background: rgba(0,0,0,0.75);</code><br />
ولی مشکل این جاست که مرورگرهایی که از RGBA پشتیبانی می کنند هم تصویر معرفی شده رو بارگذاری می کنند (کاملاً مطمئن نیستم البته. باید یه جستجویی انجام بدم.) که این به معنی یه درخواست HTTP اضافه و کاهش سرعت سایت هست.<br />
یه کتابخونه جاوااسکریپتی هست به اسم Modernizr که فقط باید بندازیدش داخل کدتون و بعد کلاس هایی رو به صفحه اضافه می کنه که مشخص می کنه آیا فلان ویژگی پشتیبانی می شه یا نه. این کتابخانه بر اساس feauture detection هست نه User-Agent Sniffing یعنی میاد بررسی می کنه ببینم مثلاً border-radius پشتیبانی می شه یا نه، نه این که بگه الان مرورگرمون IE6 هست بنابراین فلان ویژگی هستش یا نیستش.<br />
خب، حالا باید قبل از selectorتون در CSS، کلاس های مربوطه رو اضافه کنید.<br />
اطلاعات بیشتر در وب سایتش: http://www.modernizr.com/</p>
]]></content:encoded>
			<wfw:commentRss>http://tween.ir/blog/150/ccs3-%d9%88-%d9%85%d8%b4%da%a9%d9%84%d8%a7%d8%aa-%d9%be%d8%b4%d8%aa%db%8c%d8%a8%d8%a7%d9%86%db%8c-%d9%85%d8%b1%d9%88%d8%b1%da%af%d8%b1%d9%87%d8%a7/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
	</channel>
</rss>
