{"id":140,"date":"2014-11-20T11:25:45","date_gmt":"2014-11-20T18:25:45","guid":{"rendered":"http:\/\/xiaan.com\/blog\/?p=140"},"modified":"2024-02-09T15:11:07","modified_gmt":"2024-02-09T22:11:07","slug":"driving-usability-with-empirical-data","status":"publish","type":"post","link":"https:\/\/xiaan.com\/blog\/2014\/11\/driving-usability-with-empirical-data\/","title":{"rendered":"Driving Usability With Empirical Data"},"content":{"rendered":"\n<p>Too often, I work with folks that dismiss many years of interface design and information architecture experience as &#8220;your opinion&#8221; and are eager to offer their own in place of good design practices. To avoid such &#8220;he said, she said&#8221; arguments (oh, and do the right thing for the user), I\u2019m always happier when I\u2019ve got some empirical data to guide my efforts when (re)designing my user interfaces.<\/p>\n\n\n\n<p>First and foremost, data doesn&#8217;t lie. It&#8217;s often easier to champion a user interface change when there are charts, graphs, and statistics to back you up. Analyze the data and present it to stakeholders in a simple, straightforward way to support your decisions. To that end, prepare to be surprised. Sometimes the choice you thought was obvious isn&#8217;t the right one once you analyze the data.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">The Requirement<\/h2>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p>As an advanced user, in order to find the best result from a set, I wish to filter the result set by metric A, a continuous variable between 0 and 1 inclusive, shown to the user as a percent value.<\/p>\n<\/blockquote>\n\n\n\n<h2 class=\"wp-block-heading\">The Previous Implementation<\/h2>\n\n\n\n<p>A slider control was shown to users that allowed them to choose a value between 0% and 100% in 5% increments. Simple enough, but as I talked to users and examined the Google Analytics for the site, I found that very few users were using this filter. Why?<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Analyzing the Data<\/h2>\n\n\n\n<p>Metric A is a great discriminator for our data set, so why weren&#8217;t users taking advantage of this filter? I grabbed a data set of 500,000 values from our production database and started my analysis. First, some summary statistics generated with R:<\/p>\n\n\n\n<pre class=\"wp-block-preformatted\">    Min.  1st Qu.   Median     Mean  3rd Qu.     Max. \n0.000000 0.000000 0.006135 0.072020 0.098200 1.000000  \n<\/pre>\n\n\n\n<p>A basic histogram:<\/p>\n\n\n\n<div class=\"wp-block-kevinbatdorf-code-block-pro cbp-has-line-numbers\" data-code-block-pro-font-family=\"Code-Pro-JetBrains-Mono\" style=\"font-size:.875rem;font-family:Code-Pro-JetBrains-Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;--cbp-line-number-color:#24292e;--cbp-line-number-width:calc(1 * 0.6 * .875rem);line-height:1.25rem;--cbp-tab-width:2;tab-size:var(--cbp-tab-width, 2)\"><span style=\"display:flex;align-items:center;padding:16px 0 0 16px;width:100%;text-align:left;background-color:#ffffff\"><span style=\"background:#2f363c;padding:0.3rem 0.5rem 0.2rem;border-radius:1rem;font-size:0.8em;line-height:1;height:1.25rem;text-align:center;display:inline-flex;align-items:center;justify-content:center;color:#ffffff\">R<\/span><\/span><span role=\"button\" tabindex=\"0\" data-code=\"png('metricA_hist.png', width=600, height=400, units='px')\nhist(d, breaks=seq(0,1,by=0.02), freq=TRUE, main='Metric A Distribution', xaxt='n', xlab='Value (%)')\naxis(1, at=seq(0,1,by=0.2), labels=seq(0,100,by=20))\ndev.off()\" style=\"color:#24292e;display:none\" aria-label=\"Copy\" class=\"code-block-pro-copy-button\"><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" style=\"width:24px;height:24px\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\" stroke-width=\"2\"><path class=\"with-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2m-6 9l2 2 4-4\"><\/path><path class=\"without-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2\"><\/path><\/svg><\/span><pre class=\"shiki github-light\" style=\"background-color: #fff\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color: #005CC5\">png<\/span><span style=\"color: #24292E\">(<\/span><span style=\"color: #032F62\">&#39;metricA_hist.png&#39;<\/span><span style=\"color: #24292E\">, <\/span><span style=\"color: #E36209\">width<\/span><span style=\"color: #D73A49\">=<\/span><span style=\"color: #005CC5\">600<\/span><span style=\"color: #24292E\">, <\/span><span style=\"color: #E36209\">height<\/span><span style=\"color: #D73A49\">=<\/span><span style=\"color: #005CC5\">400<\/span><span style=\"color: #24292E\">, <\/span><span style=\"color: #E36209\">units<\/span><span style=\"color: #D73A49\">=<\/span><span style=\"color: #032F62\">&#39;px&#39;<\/span><span style=\"color: #24292E\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #005CC5\">hist<\/span><span style=\"color: #24292E\">(d, <\/span><span style=\"color: #E36209\">breaks<\/span><span style=\"color: #D73A49\">=<\/span><span style=\"color: #005CC5\">seq<\/span><span style=\"color: #24292E\">(<\/span><span style=\"color: #005CC5\">0<\/span><span style=\"color: #24292E\">,<\/span><span style=\"color: #005CC5\">1<\/span><span style=\"color: #24292E\">,<\/span><span style=\"color: #E36209\">by<\/span><span style=\"color: #D73A49\">=<\/span><span style=\"color: #005CC5\">0.02<\/span><span style=\"color: #24292E\">), <\/span><span style=\"color: #E36209\">freq<\/span><span style=\"color: #D73A49\">=<\/span><span style=\"color: #005CC5\">TRUE<\/span><span style=\"color: #24292E\">, <\/span><span style=\"color: #E36209\">main<\/span><span style=\"color: #D73A49\">=<\/span><span style=\"color: #032F62\">&#39;Metric A Distribution&#39;<\/span><span style=\"color: #24292E\">, <\/span><span style=\"color: #E36209\">xaxt<\/span><span style=\"color: #D73A49\">=<\/span><span style=\"color: #032F62\">&#39;n&#39;<\/span><span style=\"color: #24292E\">, <\/span><span style=\"color: #E36209\">xlab<\/span><span style=\"color: #D73A49\">=<\/span><span style=\"color: #032F62\">&#39;Value (%)&#39;<\/span><span style=\"color: #24292E\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #005CC5\">axis<\/span><span style=\"color: #24292E\">(<\/span><span style=\"color: #005CC5\">1<\/span><span style=\"color: #24292E\">, <\/span><span style=\"color: #E36209\">at<\/span><span style=\"color: #D73A49\">=<\/span><span style=\"color: #005CC5\">seq<\/span><span style=\"color: #24292E\">(<\/span><span style=\"color: #005CC5\">0<\/span><span style=\"color: #24292E\">,<\/span><span style=\"color: #005CC5\">1<\/span><span style=\"color: #24292E\">,<\/span><span style=\"color: #E36209\">by<\/span><span style=\"color: #D73A49\">=<\/span><span style=\"color: #005CC5\">0.2<\/span><span style=\"color: #24292E\">), <\/span><span style=\"color: #E36209\">labels<\/span><span style=\"color: #D73A49\">=<\/span><span style=\"color: #005CC5\">seq<\/span><span style=\"color: #24292E\">(<\/span><span style=\"color: #005CC5\">0<\/span><span style=\"color: #24292E\">,<\/span><span style=\"color: #005CC5\">100<\/span><span style=\"color: #24292E\">,<\/span><span style=\"color: #E36209\">by<\/span><span style=\"color: #D73A49\">=<\/span><span style=\"color: #005CC5\">20<\/span><span style=\"color: #24292E\">))<\/span><\/span>\n<span class=\"line\"><span style=\"color: #005CC5\">dev.off<\/span><span style=\"color: #24292E\">()<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n<figure class=\"wp-block-image\"><img loading=\"lazy\" decoding=\"async\" width=\"600\" height=\"400\" src=\"https:\/\/xiaan.com\/blog\/wp-content\/uploads\/2014\/11\/metricA_hist.png\" alt=\"Metric A Histogram\" class=\"wp-image-143\" srcset=\"https:\/\/xiaan.com\/blog\/wp-content\/uploads\/2014\/11\/metricA_hist.png 600w, https:\/\/xiaan.com\/blog\/wp-content\/uploads\/2014\/11\/metricA_hist-300x200.png 300w\" sizes=\"auto, (max-width: 600px) 100vw, 600px\" \/><\/figure>\n\n\n\n<p>And a density plot:<\/p>\n\n\n\n<div class=\"wp-block-kevinbatdorf-code-block-pro cbp-has-line-numbers\" data-code-block-pro-font-family=\"Code-Pro-JetBrains-Mono\" style=\"font-size:.875rem;font-family:Code-Pro-JetBrains-Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;--cbp-line-number-color:#24292e;--cbp-line-number-width:calc(1 * 0.6 * .875rem);line-height:1.25rem;--cbp-tab-width:2;tab-size:var(--cbp-tab-width, 2)\"><span style=\"display:flex;align-items:center;padding:16px 0 0 16px;width:100%;text-align:left;background-color:#ffffff\"><span style=\"background:#2f363c;padding:0.3rem 0.5rem 0.2rem;border-radius:1rem;font-size:0.8em;line-height:1;height:1.25rem;text-align:center;display:inline-flex;align-items:center;justify-content:center;color:#ffffff\">R<\/span><\/span><span role=\"button\" tabindex=\"0\" data-code=\"png('metricA_density.png', width=600, height=400, units='px')\nden &amp;amp;amp;amp;lt; - density(d)\nplot(den, main='Metric A Density', xaxt='n', xlab='Value (%)')\npolygon(den, col='skyblue')\naxis(1, at=seq(0,1,by=0.2), labels=seq(0,100,by=20))\ndev.off()\" style=\"color:#24292e;display:none\" aria-label=\"Copy\" class=\"code-block-pro-copy-button\"><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" style=\"width:24px;height:24px\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\" stroke-width=\"2\"><path class=\"with-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2m-6 9l2 2 4-4\"><\/path><path class=\"without-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2\"><\/path><\/svg><\/span><pre class=\"shiki github-light\" style=\"background-color: #fff\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color: #005CC5\">png<\/span><span style=\"color: #24292E\">(<\/span><span style=\"color: #032F62\">&#39;metricA_density.png&#39;<\/span><span style=\"color: #24292E\">, <\/span><span style=\"color: #E36209\">width<\/span><span style=\"color: #D73A49\">=<\/span><span style=\"color: #005CC5\">600<\/span><span style=\"color: #24292E\">, <\/span><span style=\"color: #E36209\">height<\/span><span style=\"color: #D73A49\">=<\/span><span style=\"color: #005CC5\">400<\/span><span style=\"color: #24292E\">, <\/span><span style=\"color: #E36209\">units<\/span><span style=\"color: #D73A49\">=<\/span><span style=\"color: #032F62\">&#39;px&#39;<\/span><span style=\"color: #24292E\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #24292E\">den <\/span><span style=\"color: #D73A49\">&amp;<\/span><span style=\"color: #24292E\">amp;amp;amp;lt; <\/span><span style=\"color: #D73A49\">-<\/span><span style=\"color: #24292E\"> <\/span><span style=\"color: #005CC5\">density<\/span><span style=\"color: #24292E\">(d)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #005CC5\">plot<\/span><span style=\"color: #24292E\">(den, <\/span><span style=\"color: #E36209\">main<\/span><span style=\"color: #D73A49\">=<\/span><span style=\"color: #032F62\">&#39;Metric A Density&#39;<\/span><span style=\"color: #24292E\">, <\/span><span style=\"color: #E36209\">xaxt<\/span><span style=\"color: #D73A49\">=<\/span><span style=\"color: #032F62\">&#39;n&#39;<\/span><span style=\"color: #24292E\">, <\/span><span style=\"color: #E36209\">xlab<\/span><span style=\"color: #D73A49\">=<\/span><span style=\"color: #032F62\">&#39;Value (%)&#39;<\/span><span style=\"color: #24292E\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #005CC5\">polygon<\/span><span style=\"color: #24292E\">(den, <\/span><span style=\"color: #E36209\">col<\/span><span style=\"color: #D73A49\">=<\/span><span style=\"color: #032F62\">&#39;skyblue&#39;<\/span><span style=\"color: #24292E\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #005CC5\">axis<\/span><span style=\"color: #24292E\">(<\/span><span style=\"color: #005CC5\">1<\/span><span style=\"color: #24292E\">, <\/span><span style=\"color: #E36209\">at<\/span><span style=\"color: #D73A49\">=<\/span><span style=\"color: #005CC5\">seq<\/span><span style=\"color: #24292E\">(<\/span><span style=\"color: #005CC5\">0<\/span><span style=\"color: #24292E\">,<\/span><span style=\"color: #005CC5\">1<\/span><span style=\"color: #24292E\">,<\/span><span style=\"color: #E36209\">by<\/span><span style=\"color: #D73A49\">=<\/span><span style=\"color: #005CC5\">0.2<\/span><span style=\"color: #24292E\">), <\/span><span style=\"color: #E36209\">labels<\/span><span style=\"color: #D73A49\">=<\/span><span style=\"color: #005CC5\">seq<\/span><span style=\"color: #24292E\">(<\/span><span style=\"color: #005CC5\">0<\/span><span style=\"color: #24292E\">,<\/span><span style=\"color: #005CC5\">100<\/span><span style=\"color: #24292E\">,<\/span><span style=\"color: #E36209\">by<\/span><span style=\"color: #D73A49\">=<\/span><span style=\"color: #005CC5\">20<\/span><span style=\"color: #24292E\">))<\/span><\/span>\n<span class=\"line\"><span style=\"color: #005CC5\">dev.off<\/span><span style=\"color: #24292E\">()<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n<figure class=\"wp-block-image\"><img loading=\"lazy\" decoding=\"async\" width=\"600\" height=\"400\" src=\"https:\/\/xiaan.com\/blog\/wp-content\/uploads\/2014\/11\/metricA_density.png\" alt=\"Metric A Density\" class=\"wp-image-149\" srcset=\"https:\/\/xiaan.com\/blog\/wp-content\/uploads\/2014\/11\/metricA_density.png 600w, https:\/\/xiaan.com\/blog\/wp-content\/uploads\/2014\/11\/metricA_density-300x200.png 300w\" sizes=\"auto, (max-width: 600px) 100vw, 600px\" \/><\/figure>\n\n\n\n<p>Some observations:<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>The median value is less than 1%.<\/li>\n\n\n\n<li>The interquartile range is just under 10%.<\/li>\n\n\n\n<li>The remaining values drop off after 40%.<\/li>\n<\/ul>\n\n\n\n<p>To keep things simple, we should let users filter with increased precision from 0% to 10%, and with less precision up to 40% or so.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">The New Implementation<\/h2>\n\n\n\n<p>I&#8217;ve always been a fan of jQuery and its rich plugin community. For this project, I used <a title=\"noUiSlider\" href=\"http:\/\/refreshless.com\/nouislider\/\">noUiSlider<\/a>, which has great mobile support, a clean\/responsive interface, and good documentation. The implementation was as simple as:<\/p>\n\n\n\n<div class=\"wp-block-kevinbatdorf-code-block-pro cbp-has-line-numbers\" data-code-block-pro-font-family=\"Code-Pro-JetBrains-Mono\" style=\"font-size:.875rem;font-family:Code-Pro-JetBrains-Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;--cbp-line-number-color:#24292e;--cbp-line-number-width:calc(1 * 0.6 * .875rem);line-height:1.25rem;--cbp-tab-width:2;tab-size:var(--cbp-tab-width, 2)\"><span style=\"display:flex;align-items:center;padding:16px 0 0 16px;width:100%;text-align:left;background-color:#ffffff\"><span style=\"background:#2f363c;padding:0.3rem 0.5rem 0.2rem;border-radius:1rem;font-size:0.8em;line-height:1;height:1.25rem;text-align:center;display:inline-flex;align-items:center;justify-content:center;color:#ffffff\">JavaScript<\/span><\/span><span role=\"button\" tabindex=\"0\" data-code=\"$('#elem').noUiSlider({\n  start: 0,\n  range : {\n    'min': [ 0, 0.01 ],\n    '50%': [ 0.1, 0.05 ],\n    'max': 0.50\n  }\n});\" style=\"color:#24292e;display:none\" aria-label=\"Copy\" class=\"code-block-pro-copy-button\"><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" style=\"width:24px;height:24px\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\" stroke-width=\"2\"><path class=\"with-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2m-6 9l2 2 4-4\"><\/path><path class=\"without-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2\"><\/path><\/svg><\/span><pre class=\"shiki github-light\" style=\"background-color: #fff\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color: #6F42C1\">$<\/span><span style=\"color: #24292E\">(<\/span><span style=\"color: #032F62\">&#39;#elem&#39;<\/span><span style=\"color: #24292E\">).<\/span><span style=\"color: #6F42C1\">noUiSlider<\/span><span style=\"color: #24292E\">({<\/span><\/span>\n<span class=\"line\"><span style=\"color: #24292E\">  start: <\/span><span style=\"color: #005CC5\">0<\/span><span style=\"color: #24292E\">,<\/span><\/span>\n<span class=\"line\"><span style=\"color: #24292E\">  range : {<\/span><\/span>\n<span class=\"line\"><span style=\"color: #24292E\">    <\/span><span style=\"color: #032F62\">&#39;min&#39;<\/span><span style=\"color: #24292E\">: [ <\/span><span style=\"color: #005CC5\">0<\/span><span style=\"color: #24292E\">, <\/span><span style=\"color: #005CC5\">0.01<\/span><span style=\"color: #24292E\"> ],<\/span><\/span>\n<span class=\"line\"><span style=\"color: #24292E\">    <\/span><span style=\"color: #032F62\">&#39;50%&#39;<\/span><span style=\"color: #24292E\">: [ <\/span><span style=\"color: #005CC5\">0.1<\/span><span style=\"color: #24292E\">, <\/span><span style=\"color: #005CC5\">0.05<\/span><span style=\"color: #24292E\"> ],<\/span><\/span>\n<span class=\"line\"><span style=\"color: #24292E\">    <\/span><span style=\"color: #032F62\">&#39;max&#39;<\/span><span style=\"color: #24292E\">: <\/span><span style=\"color: #005CC5\">0.50<\/span><\/span>\n<span class=\"line\"><span style=\"color: #24292E\">  }<\/span><\/span>\n<span class=\"line\"><span style=\"color: #24292E\">});<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n<p>I&#8217;ve configured noUiSlider to use the first half of the slider to allow 1 percent increments from 0 to 10 percent, and use the second half of the slider to allow 5 percent increments from 15 to 50 percent. In doing so, I&#8217;ve distributed a total of 20 options equally along the slider range.<\/p>\n\n\n\n<p>Visit <a href=\"http:\/\/refreshless.com\/nouislider\/examples\/\">http:\/\/refreshless.com\/nouislider\/examples\/<\/a> to see it in action (scroll down to see the Non-linear slider example).<\/p>\n\n\n\n<p>Hope that gives you some inspiration!<\/p>\n\n\n\n<p>Christiaan<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Too often, I work with folks that dismiss many years of interface design and information architecture experience as &#8220;your opinion&#8221; and are eager to offer their own in place of good design practices. To avoid such &#8220;he said, she said&#8221; arguments (oh, and do the right thing for the user), I\u2019m always happier when I\u2019ve &#8230;<a class=\"post-readmore\" href=\"https:\/\/xiaan.com\/blog\/2014\/11\/driving-usability-with-empirical-data\/\">read more<\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"inline_featured_image":false,"jetpack_post_was_ever_published":false,"_jetpack_newsletter_access":"","_jetpack_dont_email_post_to_subs":false,"_jetpack_newsletter_tier_id":0,"_jetpack_memberships_contains_paywalled_content":false,"_jetpack_memberships_contains_paid_content":false,"footnotes":"","jetpack_publicize_message":"","jetpack_publicize_feature_enabled":true,"jetpack_social_post_already_shared":true,"jetpack_social_options":{"image_generator_settings":{"template":"highway","default_image_id":0,"font":"","enabled":false},"version":2}},"categories":[14,11,9],"tags":[],"class_list":["post-140","post","type-post","status-publish","format-standard","hentry","category-jquery","category-r","category-usability"],"jetpack_publicize_connections":[],"jetpack_featured_media_url":"","jetpack_sharing_enabled":true,"jetpack_shortlink":"https:\/\/wp.me\/p467qb-2g","jetpack_likes_enabled":false,"_links":{"self":[{"href":"https:\/\/xiaan.com\/blog\/wp-json\/wp\/v2\/posts\/140","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/xiaan.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/xiaan.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/xiaan.com\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/xiaan.com\/blog\/wp-json\/wp\/v2\/comments?post=140"}],"version-history":[{"count":19,"href":"https:\/\/xiaan.com\/blog\/wp-json\/wp\/v2\/posts\/140\/revisions"}],"predecessor-version":[{"id":229,"href":"https:\/\/xiaan.com\/blog\/wp-json\/wp\/v2\/posts\/140\/revisions\/229"}],"wp:attachment":[{"href":"https:\/\/xiaan.com\/blog\/wp-json\/wp\/v2\/media?parent=140"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/xiaan.com\/blog\/wp-json\/wp\/v2\/categories?post=140"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/xiaan.com\/blog\/wp-json\/wp\/v2\/tags?post=140"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}