{"id":531,"date":"2010-06-21T16:42:27","date_gmt":"2010-06-21T21:42:27","guid":{"rendered":"http:\/\/www.killersites.com\/magazine\/?p=531"},"modified":"2022-08-13T10:59:21","modified_gmt":"2022-08-13T15:59:21","slug":"using-dashcode-to-develop-iphone-web-applications","status":"publish","type":"post","link":"http:\/\/www.killersites.com\/magazine\/2010\/using-dashcode-to-develop-iphone-web-applications\/","title":{"rendered":"Using Dashcode to Develop iPhone Web Applications"},"content":{"rendered":"<h2>Introduction<\/h2>\n<p><a href=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/iphone.jpeg\"><img decoding=\"async\" loading=\"lazy\" class=\"size-medium wp-image-560 alignright\" title=\"iphone\" src=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/iphone-173x300.jpg\" alt=\"\" width=\"173\" height=\"300\" srcset=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/iphone-173x300.jpg 173w, http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/iphone.jpeg 194w\" sizes=\"(max-width: 173px) 100vw, 173px\" \/><\/a><\/p>\n<p>In Getting Started with iPhone and iPad Development I introduced some of the key concepts involved with developing content for the iPhone OS platform on <a href=\"http:\/\/loans-cash.net\" style=\"color:inherit!important;text-decoration:none!important\">300 dollar loan same day<\/a>. To recap, Apple produces several devices that run the iPhone OS including:<\/p>\n<ul>\n<li>iPod Touch<\/li>\n<li><a href=\"https:\/\/casinoboms.com\/casino\/casoola\/\">Casoola Casino Ceske<\/a> iPhone<\/li>\n<li>iPad<\/li>\n<\/ul>\n<p>All of these devices allow users to both browse the web and run standalone applications, in addition to their other functions (like listening to music, making phone calls, or reading ebooks). While iPhone OS devices can load and display the same web sites as your desktop\/laptop computer, it makes sense to design content specifically for these devices.<\/p>\n<p>This article looks at Apple\u2019s Dashcode tool, which allows you to quickly produce web content that is optimized for both <a href=\"https:\/\/spielautomatennow.com\/\">online slot spiele<\/a> the Mobile Safari web browser and its big sister, the desktop version of Safari. Sites developed with Dashcode leverage Safari\u2019s support for the new HTML5 standards and allow web content developers to deliver a user experience only previously possible by relying on plugin technologies like Adobe Flash\/Flex.<\/p>\n<h2>Starting a Project<\/h2>\n<p>When you start Dashcode you are presented with a project creation screen where you can select from a number of templates.<\/p>\n<p><img decoding=\"async\" loading=\"lazy\" class=\"size-medium wp-image-544 alignnone\" title=\"Dashcode 10\" src=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode-10-300x252.png\" alt=\"\" width=\"300\" height=\"252\" srcset=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode-10-300x252.png 300w, http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode-10.png 754w\" sizes=\"(max-width: 300px) 100vw, 300px\" \/><\/p>\n<p>\ufffcThe first thing to note is that Dashcode can be used to create content for the Web as well as Mac OS X Dashboard widgets, but we\u2019ll focus on the former today. Having gotten that out of the way we can choose a template to use and in this case we\u2019ll choose the Browser template and further specify that we want to support both Safari and Mobile Safari by selecting both check boxes.<\/p>\n<p>After hitting choose, Dashcode creates your project and you\u2019ll see something like the following screen:<\/p>\n<p><a href=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Using-Dashcode2.png\"><img decoding=\"async\" loading=\"lazy\" class=\"alignnone size-medium wp-image-555\" title=\"Using Dashcode2\" src=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Using-Dashcode2-300x216.png\" alt=\"\" width=\"300\" height=\"216\" srcset=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Using-Dashcode2-300x216.png 300w, http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Using-Dashcode2-1024x739.png 1024w, http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Using-Dashcode2.png 1084w\" sizes=\"(max-width: 300px) 100vw, 300px\" \/><\/a><\/p>\n<p>\ufffcI\u2019ve highlighted a few area for further discussion. Let\u2019s start with the area in purple that lets you choose between the Safari and Mobile Safari views. In the view above we\u2019re seeing the view of the application that users would see using their desktop or laptop computer browser (as opposed to their iPhone).<\/p>\n<p>Conversely in the illustration below, we see the Mobile Safari version of the same screen.<\/p>\n<p><a href=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Using-Dashcode.png\"><img decoding=\"async\" loading=\"lazy\" class=\"alignnone size-medium wp-image-554\" title=\"Using Dashcode\" src=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Using-Dashcode-300x274.png\" alt=\"\" width=\"300\" height=\"274\" srcset=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Using-Dashcode-300x274.png 300w, http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Using-Dashcode.png 776w\" sizes=\"(max-width: 300px) 100vw, 300px\" \/><\/a><\/p>\n<p>\ufffcI\u2019ll refer to this style of Web Application as a multi-client application, meaning that the applications supports different ways of presenting information to users depending on the device they are using. While there will be a certain amount of overlap (which we definitely want to leverage) we need to cater for the limits of the iPhone\u2019s smaller screen size as compared to a laptop\/desktop display.<\/p>\n<p>The sample application generated by the template presents users with a list of locations that they can select and then see the details.<\/p>\n<p>The mobile version uses two views to present information, shown here.<\/p>\n<p><a href=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/iPhone-Simulator-2.png\"><img decoding=\"async\" loading=\"lazy\" class=\"alignnone size-medium wp-image-548\" title=\"iPhone Simulator 2\" src=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/iPhone-Simulator-2-201x300.png\" alt=\"\" width=\"201\" height=\"300\" srcset=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/iPhone-Simulator-2-201x300.png 201w, http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/iPhone-Simulator-2.png 325w\" sizes=\"(max-width: 201px) 100vw, 201px\" \/><\/a><a href=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/iPhone-Simulator.png\"><img decoding=\"async\" loading=\"lazy\" class=\"alignnone size-medium wp-image-549\" title=\"iPhone Simulator\" src=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/iPhone-Simulator-202x300.png\" alt=\"\" width=\"202\" height=\"300\" srcset=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/iPhone-Simulator-202x300.png 202w, http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/iPhone-Simulator.png 326w\" sizes=\"(max-width: 202px) 100vw, 202px\" \/><\/a><\/p>\n<p>\ufffc\ufffcThe first view is a list of locations; selecting one of the locations loads the second view which provides more detail.<\/p>\n<p>If we look at the non-mobile version of the same web application we see a single screen divided into two areas. The area to the left provides the list; selecting a specific item loads the details into the right-hand side of the screen.<\/p>\n<p>You\u2019ll note that both \ufffcthe mobile and non-mobile versions of the application provide access to the same data and indeed, the same functionality. But the non-mobile version accommodates the smaller screen size of the iPhone and presents the information in a way that is best suited to that device.<\/p>\n<p><a href=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Using-Dashcode-Dashcode.png\"><img decoding=\"async\" loading=\"lazy\" class=\"alignnone size-medium wp-image-553\" title=\"Using Dashcode [Dashcode]\" src=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Using-Dashcode-Dashcode-300x275.png\" alt=\"\" width=\"300\" height=\"275\" srcset=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Using-Dashcode-Dashcode-300x275.png 300w, http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Using-Dashcode-Dashcode.png 637w\" sizes=\"(max-width: 300px) 100vw, 300px\" \/><\/a><\/p>\n<p>On the other hand, users with bigger screens need not &nbsp;be constrained to an interface designed for a phone. The application created by the Dashcode template allows you to support both devices in a single application code base. One of the main ways it is able to do this is by using a model-view-controller design strategy. In concrete terms, all of the views (mobile or desktop) use controls that work with datasources. This is a powerful feature of Dashcode that helps promote good applications design; the payoff is the capability to support multiple client profiles in a codebase that is more easily maintained over time.<\/p>\n<p>Having looked at the sample application created by Dashcode, let\u2019s turn to the Dashcode panes as a way of developing a better understanding of how to work with the tool.<\/p>\n<h2>Dashcode Panes<\/h2>\n<h3>Outline<\/h3>\n<p>\ufffcAt the top left of the Dashcode window we can see a structural outline of the application. Dashcode provides access to a number of parts that you can drag and drop from the Dashcode Library to build your web application. Dashcode parts fall into a number of categories that include:<\/p>\n<div id=\"_mcePaste\">\n<ul>\n<li>Buttons<\/li>\n<li>Containers<\/li>\n<li>Indicators<\/li>\n<li>Media<\/li>\n<li>Text<\/li>\n<li>Shapes<\/li>\n<\/ul>\n<\/div>\n<p>The project created by the Browser template uses a \ufffcnumber of containers to organize the application\u2019s content. At the top level is the browser container which is meant to hold two children: a header and a stackLayout.<\/p>\n<p><a href=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode-9.png\"><img decoding=\"async\" loading=\"lazy\" class=\"alignnone size-medium wp-image-543\" title=\"Dashcode 9\" src=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode-9-230x300.png\" alt=\"\" width=\"230\" height=\"300\" srcset=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode-9-230x300.png 230w, http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode-9.png 241w\" sizes=\"(max-width: 230px) 100vw, 230px\" \/><\/a><a href=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Library.png\"><img decoding=\"async\" loading=\"lazy\" class=\"alignnone size-medium wp-image-552\" title=\"Library\" src=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Library-175x299.png\" alt=\"\" width=\"175\" height=\"299\" srcset=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Library-175x299.png 175w, http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Library.png 329w\" sizes=\"(max-width: 175px) 100vw, 175px\" \/><\/a><a href=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Library-2.png\"><img decoding=\"async\" loading=\"lazy\" class=\"alignnone size-medium wp-image-550\" title=\"Library 2\" src=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Library-2-300x224.png\" alt=\"\" width=\"300\" height=\"224\" srcset=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Library-2-300x224.png 300w, http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Library-2.png 320w\" sizes=\"(max-width: 300px) 100vw, 300px\" \/><\/a><\/p>\n<p>The header provides a navigation bar that includes a back button and a title to show the user where they currently are as they navigate from screen to screen.<\/p>\n<p><a href=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode1.png\"><img decoding=\"async\" loading=\"lazy\" class=\"alignnone size-medium wp-image-546\" title=\"Dashcode1\" src=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode1-231x300.png\" alt=\"\" width=\"231\" height=\"300\" srcset=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode1-231x300.png 231w, http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode1.png 341w\" sizes=\"(max-width: 231px) 100vw, 231px\" \/><\/a><\/p>\n<p>The stackLayout supports adding multiple views that can be swapped out as needed. You can think of a view as a child-container that you can add Dashcode parts to (e.g. buttons, text).<\/p>\n<p>This application includes two views (listLevel and detailLevel) which correspond to our two screens. The listLevel shows users the list of locations: clicking one of these loads the screen that shows the detail. If you are familiar with the iPhone Cocoa Touch APIs you may recognize a close analogue here to that API\u2019s NavigationController class.<\/p>\n<h2>Configuration and Deployment<\/h2>\n<p>\ufffcThe next pane I\u2019ve labelled Configuration and Deployment lacking any better term to describe it. Clicking on any of these items will bring up an editor in Dashcode\u2019s right pane that you can use to do certain things.<\/p>\n<p><a href=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode-8.png\"><img decoding=\"async\" loading=\"lazy\" class=\"alignnone size-full wp-image-542\" title=\"Dashcode 8\" src=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode-8.png\" alt=\"\" width=\"246\" height=\"133\"><\/a><\/p>\n<p>The screen shown here allows editing of a number of your applications general attributes\ufffc including the title and how your application is laid out. Of particular interest is that you can mark your application for offline viewing. This &nbsp;will allow the iPhone to download the screens and data so that users can interact with your app even when disconnected from the internet.<\/p>\n<p><a href=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode-4.png\"><img decoding=\"async\" loading=\"lazy\" class=\"alignnone size-medium wp-image-538\" title=\"Dashcode 4\" src=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode-4-300x143.png\" alt=\"\" width=\"300\" height=\"143\" srcset=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode-4-300x143.png 300w, http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode-4.png 724w\" sizes=\"(max-width: 300px) 100vw, 300px\" \/><\/a><\/p>\n<p>\ufffcThe Run and Share button brings up a screen that allows you to deploy your application to a number of locations that include your local hard disk, an FTP server or a MobileMe account.<\/p>\n<p><a href=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode2.png\"><img decoding=\"async\" loading=\"lazy\" class=\"alignnone size-medium wp-image-547\" title=\"Dashcode2\" src=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode2-300x182.png\" alt=\"\" width=\"300\" height=\"182\" srcset=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode2-300x182.png 300w, http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode2.png 726w\" sizes=\"(max-width: 300px) 100vw, 300px\" \/><\/a><\/p>\n<p>The Web Clip Icon &nbsp;button allows you to design an icon that will be associated with your web application.<\/p>\n<h2>Workflow Steps<\/h2>\n<p>\ufffcDashcode features a workflow tool (of a sort) designed to guide the user in developing their site. As seen in this screenshot, the workflow is broken down into a number of steps as follows:<\/p>\n<div id=\"_mcePaste\">\n<ul>\n<li>Lay out interface<\/li>\n<li>Customize data<\/li>\n<li>Add handlers &amp; code<\/li>\n<li>Set attributes<\/li>\n<li>Design Web Clip icon<\/li>\n<li>Test &amp; share<\/li>\n<\/ul>\n<\/div>\n<p>Each step has a corresponding expandable section that describes the workflow step and provides links to relevant Dashcode tools like the Library, Canvas, etc&#8230; \ufffc<\/p>\n<p><a href=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode-7.png\"><img decoding=\"async\" loading=\"lazy\" class=\"alignnone size-medium wp-image-541\" title=\"Dashcode 7\" src=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode-7-175x300.png\" alt=\"\" width=\"175\" height=\"300\" srcset=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode-7-175x300.png 175w, http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode-7.png 248w\" sizes=\"(max-width: 175px) 100vw, 175px\" \/><\/a><a href=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode-3.png\"><img decoding=\"async\" loading=\"lazy\" class=\"alignnone size-full wp-image-537\" title=\"Dashcode 3\" src=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode-3.png\" alt=\"\" width=\"229\" height=\"294\"><\/a><\/p>\n<p>I expect that experienced users will tend to ignore the tool. But for someone new to developing iPhone web apps with Dashcode, it can be a useful guide for getting started.<\/p>\n<h2>Files<\/h2>\n<p>\ufffcOf course what you are actually working with when using Dashcode are files. Naturally enough these include:<\/p>\n<div id=\"_mcePaste\">\n<ul>\n<li>HTML<\/li>\n<li>Javascript<\/li>\n<li>Cascading Style Sheets<\/li>\n<li>Images (e.g. PNG files)<\/li>\n<\/ul>\n<\/div>\n<p><a href=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode-2.png\"><img decoding=\"async\" loading=\"lazy\" class=\"alignnone size-full wp-image-536\" title=\"Dashcode 2\" src=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode-2.png\" alt=\"\" width=\"242\" height=\"245\"><\/a><\/p>\n<p>\ufffcYou can edit these directly using the editor Dashcode provides. The editor provides the usual features &nbsp;such as syntax highlighting and code completion. There is an issue if you want to edit these files with another editor: your files are stored in a Mac OS X Package and that makes using external tools in conjunction with Dashcode tricky. There\u2019s probably a way to do it but it may require jumping through some hoops.<\/p>\n<p><a href=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode.png\"><img decoding=\"async\" loading=\"lazy\" class=\"alignnone size-medium wp-image-545\" title=\"Dashcode\" src=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode-300x149.png\" alt=\"\" width=\"300\" height=\"149\" srcset=\"http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode-300x149.png 300w, http:\/\/www.killersites.com\/magazine\/wp-content\/uploads\/2010\/06\/Dashcode.png 754w\" sizes=\"(max-width: 300px) 100vw, 300px\" \/><\/a><\/p>\n<p>While Dashcode does provide tools that \u2018wrap\u2019 the files, you will probably need to edit those files yourself at some point to add some customization. For instance you\u2019ll want to write some Javascript to handle events like clicking on a button. While Dashcode will generate stub implementations of these at the click of a button, you will need to finish them off. Luckily the Dashcode Library contains a tab with code snippets that you can customize as needed.<\/p>\n<h2>Conclusion<\/h2>\n<p>Dashcode provides web application developers with an easy-to-use tool that can be used to develop sites specifically designed for both the mobile and standard versions of Safari. Users of this tool will almost certainly be mainly (if not exclusively) interested in using it to build their iPhone and iPad compatible sites.<\/p>\n<p>It should be remembered though that Apple\u2019s commitment to open web standards is actually pretty good. With some care (and lots of testing) there is no reason you cannot develop sites that work across a range of devices.<\/p>\n<p>In a future article, I\u2019ll dig deeper into the tools provided by Dashcode with particular emphasis on Dashcode parts and how they can be used to build sites with a rich user interface.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Introduction In Getting Started with iPhone and iPad Development I introduced some of the key concepts involved with developing content for the iPhone OS platform on 300 dollar loan same day. To recap, Apple produces several devices that run the iPhone OS including: iPod Touch Casoola Casino Ceske iPhone iPad All of these devices allow [&hellip;]<\/p>\n","protected":false},"author":12,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":[],"categories":[1],"tags":[],"_links":{"self":[{"href":"http:\/\/www.killersites.com\/magazine\/wp-json\/wp\/v2\/posts\/531"}],"collection":[{"href":"http:\/\/www.killersites.com\/magazine\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/www.killersites.com\/magazine\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/www.killersites.com\/magazine\/wp-json\/wp\/v2\/users\/12"}],"replies":[{"embeddable":true,"href":"http:\/\/www.killersites.com\/magazine\/wp-json\/wp\/v2\/comments?post=531"}],"version-history":[{"count":13,"href":"http:\/\/www.killersites.com\/magazine\/wp-json\/wp\/v2\/posts\/531\/revisions"}],"predecessor-version":[{"id":4916,"href":"http:\/\/www.killersites.com\/magazine\/wp-json\/wp\/v2\/posts\/531\/revisions\/4916"}],"wp:attachment":[{"href":"http:\/\/www.killersites.com\/magazine\/wp-json\/wp\/v2\/media?parent=531"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/www.killersites.com\/magazine\/wp-json\/wp\/v2\/categories?post=531"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/www.killersites.com\/magazine\/wp-json\/wp\/v2\/tags?post=531"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}