Embedded Viewer API به شما امکان می دهد محتوای کتاب را از Google Books مستقیماً در صفحات وب خود با جاوا اسکریپت جاسازی کنید. API همچنین تعدادی ابزار برای دستکاری پیشنمایش کتابها فراهم میکند و اغلب همراه با سایر APIهای توضیح داده شده در این سایت استفاده میشود.
جادوگر پیشنمایش ابزاری است که بر روی Embedded Viewer API ساخته شده است که تنها با کپی کردن چند خط کد، افزودن قابلیتهای پیشنمایش به سایت شما را آسانتر میکند. این سند برای توسعه دهندگان پیشرفته تری در نظر گرفته شده است که به دنبال سفارشی کردن نحوه نمایش بیننده در سایت های خود هستند.
مخاطب
این مستندات برای افرادی که با برنامه نویسی جاوا اسکریپت و مفاهیم برنامه نویسی شی گرا آشنا هستند طراحی شده است. همچنین باید از دیدگاه کاربر با Google Books آشنا باشید. بسیاری از آموزش های جاوا اسکریپت در وب وجود دارد.
این مستندات مفهومی کامل و جامع نیست. این برنامه به گونه ای طراحی شده است که به شما امکان می دهد به سرعت شروع به کاوش و توسعه برنامه های کاربردی جالب با Embedded Viewer API کنید. کاربران پیشرفته ممکن است به مرجع API نمایشگر جاسازی شده علاقه مند شوند، که جزئیات جامعی در مورد روش ها و پاسخ های پشتیبانی شده ارائه می دهد.
همانطور که در بالا ذکر شد، مبتدیان ممکن است بخواهند با پیش نمایش جادوگر شروع کنند، که به طور خودکار کد لازم برای جاسازی پیش نمایش های اولیه در سایت شما را تولید می کند.
"Hello, World" از Embedded Viewer API
ساده ترین راه برای شروع یادگیری در مورد Embedded Viewer API دیدن یک مثال ساده است. صفحه وب زیر یک پیشنمایش 600x500 از Mountain View ، توسط نیکلاس پری، ISBN 0738531367 (بخشی از مجموعه «تصاویر آمریکا» انتشارات Arcadia) را نشان میدهد:
<!DOCTYPE html "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <title>Google Books Embedded Viewer API Example</title> <script type="text/javascript" src="https://www.google.com/books/jsapi.js"></script> <script type="text/javascript"> google.books.load(); function initialize() { var viewer = new google.books.DefaultViewer(document.getElementById('viewerCanvas')); viewer.load('ISBN:0738531367'); } google.books.setOnLoadCallback(initialize); </script> </head> <body> <div id="viewerCanvas" style="width: 600px; height: 500px"></div> </body> </html>
می توانید به این مثال نگاه کنید و آن را برای ویرایش و بازی با آن دانلود کنید. حتی در این مثال ساده، پنج نکته قابل توجه است:
- ما API Loader را با استفاده از یک تگ
script
اضافه می کنیم. - ما یک عنصر
div
به نام "viewerCanvas" ایجاد می کنیم تا بیننده را نگه دارد. - ما یک تابع جاوا اسکریپت می نویسیم تا یک شی "نمایشگر" ایجاد کنیم.
- ما کتاب را با استفاده از شناسه منحصر به فرد آن بارگذاری می کنیم (در این مورد
ISBN:0738531367
). - ما از
google.books.setOnLoadCallback
برای فراخوانیinitialize
زمانی که API به طور کامل بارگیری شد استفاده می کنیم.
این مراحل در زیر توضیح داده شده است.
در حال بارگیری Embedded Viewer API
استفاده از چارچوب API Loader برای بارگذاری Embedded Viewer API نسبتا ساده است. این شامل دو مرحله زیر است:
- شامل کتابخانه API Loader:
<script type="text/javascript" src="https://www.google.com/books/jsapi.js"></script>
- روش
google.books.load
را فراخوانی کنید. روشgoogle.books.load
یک پارامتر فهرست اختیاری را می گیرد که تابع یا زبان بازگشت به تماس را مشخص می کند، همانطور که در زیر توضیح داده شده است.<script type="text/javascript"> google.books.load(); </script>
در حال بارگیری یک نسخه بومی سازی شده از Embedded Viewer API
Embedded Viewer API هنگام نمایش اطلاعات متنی مانند نکات ابزار، نام کنترل ها و متن پیوند به طور پیش فرض از زبان انگلیسی استفاده می کند. اگر میخواهید Embedded Viewer API را تغییر دهید تا اطلاعات به زبان خاصی نمایش داده شود، میتوانید یک پارامتر language
اختیاری را به تماس google.books.load
خود اضافه کنید.
به عنوان مثال، برای نمایش یک ماژول پیش نمایش کتاب با زبان رابط پرتغالی برزیل:
<script type="text/javascript"> google.books.load({"language": "pt-BR"}); </script>
مشاهده نمونه (book-language.html)
کدهای زبان RFC 3066 پشتیبانی شده در حال حاضر شامل af، ar، hy، bg، ca، zh-CN، zh-TW، hr، cs، da، nl، en، fil، fi، fr، de، el، he، hu، is , id, it, ja, ko, lv, lt, ms, no, pl, pt-BR, pt-PT, ro, ru, sr, sk, sl, es, sv, tl, th, tr, uk, و vi.
هنگام استفاده از Embedded Viewer API در زبانهایی غیر از انگلیسی، اکیداً توصیه میکنیم صفحه خود را با یک سرصفحه content-type
تنظیم شده روی utf-8
یا یک تگ <meta>
معادل در صفحه خود قرار دهید. انجام این کار کمک می کند تا اطمینان حاصل شود که کاراکترها به درستی در همه مرورگرها ارائه می شوند. برای اطلاعات بیشتر، به صفحه W3C در مورد تنظیم پارامتر مجموعه حروف HTTP مراجعه کنید.
عناصر DOM بیننده
<div id="viewerCanvas" style="width: 600px; height: 500px"></div>
برای اینکه یک کتاب در یک صفحه وب نمایش داده شود، باید جایی برای آن رزرو کنید. معمولاً این کار با ایجاد یک عنصر div
با نام و به دست آوردن ارجاع به این عنصر در مدل شی سند مرورگر (DOM) انجام می شود.
مثال بالا یک div
با نام "viewerCanvas" را تعریف می کند و اندازه آن را با استفاده از ویژگی های سبک تنظیم می کند. بیننده به طور ضمنی از اندازه ظرف برای اندازه گیری خود استفاده می کند.
شی DefaultViewer
var viewer = new google.books.DefaultViewer(document.getElementById('viewerCanvas'));
کلاس جاوا اسکریپت که یک بیننده را در صفحه ایجاد و کنترل می کند، کلاس DefaultViewer
است. (شما می توانید بیش از یک نمونه از این کلاس ایجاد کنید - هر شی یک نمایشگر جداگانه در صفحه تعریف می کند.) یک نمونه جدید از این کلاس با استفاده از عملگر new
جاوا اسکریپت ایجاد می شود.
هنگامی که یک نمونه بیننده جدید ایجاد می کنید، یک گره DOM را در صفحه (معمولا یک عنصر div
) به عنوان یک ظرف برای بیننده مشخص می کنید. گره های HTML فرزندان شی document
جاوا اسکریپت هستند و ما از طریق متد document.getElementById()
به این عنصر ارجاع می دهیم.
این کد یک متغیر ( viewer
نام) را تعریف می کند و آن متغیر را به یک شی DefaultViewer
جدید اختصاص می دهد. تابع DefaultViewer()
به عنوان سازنده شناخته می شود و تعریف آن (برای وضوح از مرجع API مشاهده کننده جاسازی شده فشرده شده است) در زیر نشان داده شده است:
سازنده | توضیحات |
---|---|
DefaultViewer ( کانتینر ، گزینه ها؟ ) | یک بیننده جدید در داخل container HTML داده شده ایجاد می کند که باید یک عنصر در سطح بلوک در صفحه باشد (معمولاً یک DIV ). گزینه های پیشرفته با استفاده از پارامتر opts اختیاری ارسال می شوند. |
توجه داشته باشید که پارامتر دوم در سازنده اختیاری است - که برای پیاده سازی های پیشرفته خارج از محدوده این سند در نظر گرفته شده است - و از مثال "Hello, World" حذف شده است.
آغاز کردن بیننده با یک کتاب خاص
viewer.load('ISBN:0738531367');
هنگامی که یک نمایشگر از طریق سازنده DefaultViewer
ایجاد کردیم، باید با یک کتاب خاص مقداردهی اولیه شود. این مقداردهی اولیه با استفاده از متد load()
viewer's انجام می شود. متد load()
به یک مقدار identifier
نیاز دارد که به API می گوید چه کتابی را نشان دهد. این روش باید قبل از انجام هر گونه عملیات دیگری بر روی شی viewer ارسال شود.
اگر چندین شناسه برای یک کتاب میشناسید - ISBN برای نسخه شومیز، یا اعداد OCLC جایگزین - میتوانید آرایهای از رشتههای شناسه را بهعنوان اولین پارامتر به تابع load()
بفرستید. اگر پیشنمایش قابل جاسازی مرتبط با هر یک از شناسههای آرایه وجود داشته باشد، بیننده کتاب را ارائه میکند.
شناسه های کتاب پشتیبانی شده
همانند ویژگی Dynamic Links ، Embedded Viewer API از تعدادی مقادیر برای شناسایی یک کتاب خاص پشتیبانی می کند. این موارد عبارتند از:
- شابک
- شماره کتاب استاندارد بین المللی تجاری 10 یا 13 رقمی منحصر به فرد.
مثال:ISBN:0738531367
- شماره OCLC
- شماره منحصر به فردی که توسط OCLC به یک کتاب اختصاص داده می شود، زمانی که رکورد کتاب به سیستم فهرست نویسی WorldCat اضافه می شود.
مثال:OCLC:70850767
- LCCN
- شماره کنترل کتابخانه کنگره که توسط کتابخانه کنگره به رکورد اختصاص داده شده است.
مثال:LCCN:2006921508
- شناسه جلد Google Books
- رشته منحصر به فردی که Google Books به حجم اختصاص داده است، که در URL کتاب در Google Books ظاهر می شود.
مثال:Py8u3Obs4f4C
- نشانی وب پیشنمایش کتابهای Google
- نشانی اینترنتی که صفحه پیشنمایش کتاب را در Google Books باز میکند.
مثال:https://books.google.com/books?id=Py8u3Obs4f4C&printsec=frontcover
این شناسهها اغلب با سایر APIهای خانواده Google Books API استفاده میشوند. برای مثال، تنها در صورتی میتوانید از پیوندهای پویا برای ارائه یک دکمه پیشنمایش استفاده کنید که کتاب قابل جاسازی باشد—و سپس، زمانی که کاربر روی دکمه کلیک میکند، یک بیننده را با استفاده از URL پیشنمایش بازگردانده شده توسط تماس پیوندهای پویا ، نمونهسازی کنید. به طور مشابه، میتوانید یک برنامه مرور و پیشنمایش غنی با Books API بسازید که چندین شناسه صنعتی مناسب را در فیدهای Volumes خود برمیگرداند. برای مشاهده برخی از پیاده سازی های پیشرفته، از صفحه نمونه ها دیدن کنید.
مدیریت اولیه سازی های ناموفق
در برخی موارد، تماس load
ممکن است با شکست مواجه شود. معمولاً زمانی که API نمی تواند کتاب مرتبط با شناسه ارائه شده را پیدا کند، زمانی که هیچ پیش نمایشی از کتاب در دسترس نیست، زمانی که پیش نمایش کتاب نمی تواند جاسازی شود، یا زمانی که محدودیت های منطقه ای کاربر نهایی را از دیدن این کتاب خاص جلوگیری می کند، رخ می دهد. ممکن است بخواهید در مورد چنین شکستی هشدار داده شود، بنابراین کد شما می تواند این شرایط را به خوبی مدیریت کند. به همین دلیل، تابع load
به شما امکان می دهد یک پارامتر دوم اختیاری، notFoundCallback
را ارسال کنید، که نشان می دهد اگر کتاب بارگیری نمی شود، چه تابعی باید فراخوانی شود. برای مثال، اگر کتاب قابل جاسازی باشد، کد زیر یک جعبه هشدار جاوا اسکریپت ایجاد می کند:
function alertNotFound() { alert("could not embed the book!"); } function initialize() { var viewer = new google.books.DefaultViewer(document.getElementById('viewerCanvas')); viewer.load('ISBN:1234', alertNotFound); }
مشاهده نمونه (book-notfound.html)
با استفاده از این تماس، ممکن است تصمیم بگیرید که خطای مشابهی را نشان دهید، یا ممکن است انتخاب کنید که عنصر viewerCanvas
را به طور کامل پنهان کنید. پارامتر پاسخ به تماس شکست اختیاری است و در مثال "Hello World" گنجانده نشده است.
توجه : از آنجایی که پیشنمایشها ممکن است برای همه کتابها و برای همه کاربران در دسترس نباشد، ممکن است قبل از اینکه بخواهید یک بیننده برای آن بارگیری کنید، بدانید که آیا پیشنمایش در دسترس است یا خیر. برای مثال، ممکن است بخواهید دکمه، صفحه یا بخش «پیشنمایش Google» را در رابط کاربری خود نشان دهید تنها در صورتی که یک پیشنمایش واقعاً در دسترس کاربر باشد. میتوانید این کار را با استفاده از Books API یا Dynamic Links انجام دهید، که هر دو گزارش میدهند که آیا کتابی برای جاسازی با استفاده از بیننده در دسترس خواهد بود یا خیر.
مدیریت اولیه سازی های موفق
همچنین ممکن است دانستن اینکه آیا کتاب با موفقیت بارگیری شده است یا خیر مفید باشد. به همین دلیل، تابع load
از پارامتر سوم اختیاری، successCallback
پشتیبانی میکند، که در صورت پایان بارگیری کتاب اجرا میشود.
function alertInitialized() { alert("book successfully loaded and initialized!"); } function initialize() { var viewer = new google.books.DefaultViewer(document.getElementById('viewerCanvas')); viewer.load('ISBN:0738531367', null, alertInitialized); }
مشاهده نمونه (book-success.html)
برای مثال، اگر بخواهید فقط در صورتی که بیننده به طور کامل رندر کرده باشد، عناصر خاصی را در صفحه خود نشان دهید، این پاسخ تماس ممکن است مفید باشد.
نمایش بیننده در حالت بارگذاری
google.books.setOnLoadCallback(initialize);
در حالی که یک صفحه HTML ارائه می شود، مدل شی سند (DOM) ساخته می شود و هر تصویر و اسکریپت خارجی دریافت می شود و در شی document
گنجانده می شود. برای اطمینان از اینکه بیننده ما فقط پس از بارگیری کامل صفحه در صفحه قرار می گیرد، از تابع google.books.setOnLoadCallback
برای به تعویق انداختن اجرای تابعی استفاده می شود که شی DefaultViewer
را می سازد. از آنجایی که setOnLoadCallback
فقط زمانی که Embedded Viewer API بارگیری شده و آماده استفاده باشد، initialize
فراخوانی می کند، این امر از رفتار غیرقابل پیش بینی جلوگیری می کند و کنترل نحوه و زمان ترسیم بیننده را تضمین می کند.
توجه: برای به حداکثر رساندن سازگاری بین مرورگرها، اکیداً توصیه میشود که بارگیری بیننده را با استفاده از تابع google.books.setOnLoadCallback
به جای استفاده از یک رویداد onLoad
در تگ <body>
خود برنامهریزی کنید.
تعامل بیننده
اکنون که یک شی DefaultViewer
دارید، می توانید با آن تعامل داشته باشید. شیء اصلی بیننده بسیار شبیه بینندهای است که با آن در وبسایت Google Books تعامل دارید و رفتارهای داخلی زیادی دارد.
اما شما همچنین می توانید به صورت برنامه ای با بیننده تعامل داشته باشید. شی DefaultViewer
از تعدادی روش پشتیبانی می کند که مستقیماً وضعیت پیش نمایش را تغییر می دهد. برای مثال، متدهای zoomIn()
، nextPage()
و highlight()
بر روی بیننده به صورت برنامه نویسی عمل می کنند، نه از طریق تعامل با کاربر.
مثال زیر یک پیشنمایش کتاب را نشان میدهد که هر 3 ثانیه بهطور خودکار به صفحه بعدی تبدیل میشود. اگر صفحه بعدی در قسمت قابل مشاهده بیننده باشد، بیننده به آرامی به صفحه حرکت می کند. اگر نه، بیننده مستقیماً به بالای صفحه بعدی میپرد.
function nextStep(viewer) { window.setTimeout(function() { viewer.nextPage(); nextStep(viewer); }, 3000); } function initialize() { var viewer = new google.books.DefaultViewer(document.getElementById('viewerCanvas')); viewer.load('ISBN:0738531367'); nextStep(viewer); } google.books.setOnLoadCallback(initialize);
مشاهده نمونه (book-animate.html)
توجه داشته باشید که تا زمانی که بیننده به طور کامل با یک کتاب خاص مقداردهی اولیه نشود، تماسهای برنامهای با بیننده ناموفق خواهند بود یا تأثیری ندارند. برای اطمینان از فراخوانی چنین توابعی فقط زمانی که بیننده آماده است، از پارامتر successCallback
برای viewer.load
همانطور که در بالا توضیح داده شد استفاده کنید.
برای اطلاعات در مورد تمام توابع پشتیبانی شده توسط شی DefaultViewer
، به راهنمای مرجع مراجعه کنید.
یادداشت های برنامه نویسی
قبل از شروع به جستجو در Embedded Viewer API، باید به نگرانیهای زیر توجه داشته باشید تا مطمئن شوید که برنامه شما در پلتفرمهای مورد نظر خود به خوبی کار میکند.
سازگاری با مرورگر
Embedded Viewer API از نسخههای اخیر اینترنت اکسپلورر، فایرفاکس و سافاری و معمولاً سایر مرورگرهای مبتنی بر Gecko و WebKit مانند Camino و Google Chrome نیز پشتیبانی میکند.
گاهی اوقات برنامه های مختلف برای کاربران با مرورگرهای ناسازگار رفتارهای متفاوتی را می طلبند. Embedded Viewer API هنگامی که یک مرورگر ناسازگار را شناسایی می کند، هیچ رفتار خودکاری ندارد. بیشتر نمونههای موجود در این سند سازگاری مرورگر را بررسی نمیکنند و برای مرورگرهای قدیمیتر پیام خطا نشان نمیدهند. برنامههای کاربردی واقعی ممکن است با مرورگرهای قدیمی یا ناسازگار کار دوستانهتری انجام دهند، اما چنین بررسیهایی برای خواناییتر کردن مثالها حذف میشوند.
برنامه های غیر پیش پا افتاده به ناچار با ناهماهنگی هایی بین مرورگرها و پلتفرم ها مواجه می شوند. سایتهایی مانند quirksmode.org نیز منابع خوبی برای یافتن راهحلها هستند.
حالت XHTML و quirks
توصیه می کنیم از XHTML سازگار با استانداردها در صفحاتی که دارای نمایشگر هستند استفاده کنید. وقتی مرورگرها XHTML DOCTYPE
در بالای صفحه میبینند، صفحه را در «حالت انطباق با استانداردها» نمایش میدهند، که طرحبندی و رفتارها را در مرورگرها قابل پیشبینیتر میکند. صفحات بدون آن تعریف ممکن است در " حالت عجیب و غریب " ارائه شوند، که می تواند منجر به چیدمان ناسازگار شود.
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html xmlns="http://www.w3.org/1999/xhtml">
یادداشتی در مورد نمونههای Embedded Viewer API
توجه داشته باشید که بیشتر نمونههای موجود در این مستندات فقط کد جاوا اسکریپت مربوطه را نشان میدهند، نه فایل کامل HTML. میتوانید کد جاوا اسکریپت را به فایل HTML اسکلت خود متصل کنید، یا میتوانید فایل کامل HTML را برای هر نمونه با کلیک کردن روی پیوند بعد از مثال دانلود کنید.
عیب یابی
اگر به نظر می رسد کد شما کار نمی کند، در اینجا چند روش وجود دارد که ممکن است به شما در حل مشکلات کمک کند:
- به دنبال اشتباهات تایپی باشید به یاد داشته باشید که جاوا اسکریپت یک زبان حساس به حروف بزرگ و کوچک است.
- از یک دیباگر جاوا اسکریپت استفاده کنید. در فایرفاکس، میتوانید از کنسول جاوا اسکریپت، Venkman Debugger یا افزونه Firebug استفاده کنید. در اینترنت اکسپلورر، می توانید از Microsoft Script Debugger استفاده کنید. مرورگر گوگل کروم دارای تعدادی ابزار توسعه است که مستقیماً در آن تعبیه شده است، از جمله بازرس DOM و دیباگر جاوا اسکریپت.