{"id":1195,"date":"2013-10-13T16:48:33","date_gmt":"2013-10-13T07:48:33","guid":{"rendered":"http:\/\/appsweets.net\/blog\/?p=1195"},"modified":"2013-10-13T18:34:54","modified_gmt":"2013-10-13T09:34:54","slug":"visual-in-vi-2","status":"publish","type":"post","link":"http:\/\/appsweets.net\/blog\/2013\/10\/13\/visual-in-vi-2\/","title":{"rendered":"visual in vi #2"},"content":{"rendered":"<div class=\"856f7bdf6ce2541193600c6e03dd1a56\" data-index=\"1\" style=\"float: left; margin: 16px 16px 16px 0;\">\n<script type=\"text\/javascript\"><!--\r\ngoogle_ad_client = \"ca-pub-5825700137064158\";\r\n\/* 250sq, appsweets-blog *\/\r\ngoogle_ad_slot = \"4837931762\";\r\ngoogle_ad_width = 250;\r\ngoogle_ad_height = 250;\r\n\/\/-->\r\n<\/script>\r\n<script type=\"text\/javascript\"\r\nsrc=\"http:\/\/pagead2.googlesyndication.com\/pagead\/show_ads.js\">\r\n<\/script>\n<\/div>\n<p>\u307e\u305a\u30e2\u30fc\u30c9\u540d\u3060\u304c\u3001vim \u306e\u3088\u3046\u306b visual \u30e2\u30fc\u30c9\u3067\u306f\u306a\u304f\u3001bound \u30e2\u30fc\u30c9\u3068\u547c\u3076\u3053\u3068\u306b\u3057\u305f\u3044\u3002\u3082\u3057\u304b\u3057\u305f\u3089 region \u30e2\u30fc\u30c9\u306b\u3059\u308b\u304b\u3082\u3057\u308c\u306a\u3044\u3002<\/p>\n<p>\u3053\u308c\u3092\u5b9f\u88c5\u3059\u308b\u306b\u3042\u305f\u3063\u3066\u3001\u5185\u90e8\u7684\u306b\u306f\u3001\u672c\u8cea\u7684\u306b\u306f\u5358\u306b\u9078\u629e\u9818\u57df\u306e 2 \u3064\u306e\u7aef\u70b9\u3060\u3051\u3092\u7ba1\u7406\u3059\u308b\u3060\u3051\u306e\u8a71\u3060\u3002bound \u30e2\u30fc\u30c9\u3067\u306f\u30ab\u30fc\u30bd\u30eb\u304c\u884c\u672b\u306e\u6539\u884c\u306b\u3082\u4e57\u308c\u308b\u3088\u3046\u306b\u3059\u308b\u3001\u3068\u304b\u30ab\u30fc\u30bd\u30eb\uff08\u9078\u629e\u306e\u7d42\u4e86\u70b9\uff09\u304c\u9078\u629e\u306e\u958b\u59cb\u70b9\u306e\u524d\u3078\u884c\u3063\u305f\u6642\u306e\u3064\u3058\u3064\u307e\u5408\u308f\u305b\u3068\u304b\u3001\u7d30\u3005\u3068\u3057\u305f\u3082\u306e\u306f\u3042\u308b\u3051\u308c\u3069\u3001\u5185\u90e8\u7684\u306b\u306f\u7d50\u5c40\u306f 2 \u3064\u306e\u7aef\u70b9\u3060\u3002<\/p>\n<p>\u4e00\u65b9\u3067\u3001vim \u3067 visual \u30e2\u30fc\u30c9\u3068\u3044\u3046\u3060\u3051\u3042\u3063\u3066\u3001\u898b\u305f\u76ee\u306e\u90e8\u5206\u304c\u91cd\u8981\u3060\u3002\u3064\u307e\u308a\u9078\u629e\u4e2d\u306e\u9818\u57df\u3092\u53cd\u8ee2\u8868\u793a\u3055\u305b\u306a\u3044\u3068\u3044\u3051\u306a\u3044\u3002DOM \u3067\u3053\u308c\u3092\u3069\u3046\u5b9f\u73fe\u3059\u308b\u304b\uff1f<\/p>\n<p>\u307e\u305a\u30d6\u30e9\u30a6\u30b6\u304c\u6301\u3064\u6a19\u6e96\u306e\u7bc4\u56f2\u9078\u629e\u306e\u4ed5\u7d44\u307f\u3092\u30d6\u30e9\u30a6\u30b6\u304b\u3089\u5236\u5fa1\u3059\u308b\u305f\u3081\u306b <a href=\"https:\/\/developer.mozilla.org\/ja\/docs\/Web\/API\/Selection\" target=\"_blank\">selection<\/a> \u304c\u3042\u308b\u3002\u3053\u308c\u3060\u3068\u307e\u3055\u306b\u9078\u629e\u9818\u57df\u306e\u4e21\u7aef\u70b9\u3092\u6307\u5b9a\u3059\u308b\u3060\u3051\u3067\u3044\u3044\u3002<br \/>\n<code lang=\"javascript\"><br \/>\nvar r = window.getSelection().getRangeAt(0);<br \/>\nr.setStart(text_node_of_lower_side, column_of_its_index);<br \/>\nr.setEnd(text_node_of_higher_side, column_of_its_index);<br \/>\n<\/code><br \/>\n\u305f\u3060\u3001\u305d\u308c\u304c\u3069\u3046\u8868\u793a\u3055\u308c\u308b\u304b\u306f\u5168\u304f\u30d6\u30e9\u30a6\u30b6\u4efb\u305b\u306b\u306a\u308b\u3002\u3053\u308c\u306f\u5b9f\u969b\u697d\u306a\u306e\u3060\u3051\u3069\u3001wasavi \u5074\u306e\u30c6\u30fc\u30de\u306b\u3088\u3063\u3066\u306f\u5224\u5225\u3057\u3065\u3089\u3044\u3082\u306e\u306b\u306a\u308b\u304b\u3082\u3057\u308c\u306a\u3044\u3002<\/p>\n<p>\u6b21\u306b DOM \u30ec\u30d9\u30eb\u3067\u9078\u629e\u7bc4\u56f2\u3092 span \u3067\u304f\u304f\u308a\u3060\u3059\u65b9\u6cd5\u3082\u3042\u308b\u3002\u3053\u3061\u3089\u306f\u9078\u629e\u9818\u57df\u306e\u66f4\u65b0\u3092\u81ea\u524d\u3067\u3084\u3089\u306a\u3044\u3051\u308c\u3070\u3044\u3051\u306a\u3044\u306e\u304c\u30cd\u30c3\u30af\u306b\u306a\u308b\u3002\u4e00\u756a\u7c21\u5358\u306a\u306e\u306f\u3001\u66f4\u65b0\u524d\u306b\u4e00\u65e6\u3059\u3079\u3066\u306e\u9078\u629e\u9818\u57df\u3092\u30af\u30ea\u30a2\u3057\uff08\u3064\u307e\u308a span \u3067\u304f\u304f\u308a\u3060\u3055\u308c\u305f\u90e8\u5206\u3092\u8131\u76ae\u3055\u305b\u308b\uff09\u3001\u518d\u5ea6\u9078\u629e\u7bc4\u56f2\u3092\u304f\u304f\u308a\u3060\u3059\u306e\u3067\u3042\u308b\u3002\u3053\u308c\u3060\u3068\u7279\u306b\u9078\u629e\u7bc4\u56f2\u304c\u4f55\u5341\u884c\u306b\u3082\u53ca\u3076\u5834\u5408\u306b\u660e\u3089\u304b\u306b\u9045\u304f\u306a\u308a\u305d\u3046\u3067\u306f\u3042\u308b\u306e\u3067\u3001\u5b9f\u969b\u306f\u305d\u306e\u3078\u3093\u306f\u5dee\u5206\u3067\u7ba1\u7406\u3057\u306a\u3044\u3068\u3044\u3051\u306a\u3044\u306f\u305a\u3060\u3002<\/p>\n<p>\u305d\u3046\u3044\u3046\u308f\u3051\u3067\u3053\u3093\u306a\u304b\u3093\u3058\u306b\u306a\u308b\u3002\u3044\u305f\u3063\u3066\u3075\u3064\u30fc\u3002<\/p>\n<p><a href=\"http:\/\/appsweets.net\/blog\/2013\/10\/13\/visual-in-vi-2\/bounding\/\" rel=\"attachment wp-att-1196\"><img loading=\"lazy\" decoding=\"async\" src=\"http:\/\/appsweets.net\/blog\/wp-content\/uploads\/2013\/10\/bounding.png\" alt=\"bounding\" width=\"447\" height=\"361\" class=\"aligncenter size-full wp-image-1196\" \/><\/a><\/p>\n<div class=\"856f7bdf6ce2541193600c6e03dd1a56\" data-index=\"1\" style=\"float: left; margin: 16px 16px 16px 0;\">\n<script type=\"text\/javascript\"><!--\r\ngoogle_ad_client = \"ca-pub-5825700137064158\";\r\n\/* 250sq, appsweets-blog *\/\r\ngoogle_ad_slot = \"4837931762\";\r\ngoogle_ad_width = 250;\r\ngoogle_ad_height = 250;\r\n\/\/-->\r\n<\/script>\r\n<script type=\"text\/javascript\"\r\nsrc=\"http:\/\/pagead2.googlesyndication.com\/pagead\/show_ads.js\">\r\n<\/script>\n<\/div>\n\n<div style=\"font-size: 0px; height: 0px; line-height: 0px; margin: 0; padding: 0; clear: both;\"><\/div>","protected":false},"excerpt":{"rendered":"<p>\u307e\u305a\u30e2\u30fc\u30c9\u540d\u3060\u304c\u3001vim \u306e\u3088\u3046\u306b visual \u30e2\u30fc\u30c9\u3067\u306f\u306a\u304f\u3001bound \u30e2\u30fc\u30c9\u3068\u547c\u3076\u3053\u3068\u306b\u3057\u305f\u3044\u3002\u3082\u3057\u304b\u3057\u305f\u3089 region \u30e2\u30fc\u30c9\u306b\u3059\u308b\u304b\u3082\u3057\u308c\u306a\u3044\u3002 \u3053\u308c\u3092\u5b9f\u88c5\u3059\u308b\u306b\u3042\u305f\u3063\u3066\u3001\u5185\u90e8\u7684\u306b\u306f\u3001\u672c\u8cea\u7684\u306b\u306f\u5358\u306b\u9078\u629e\u9818\u57df\u306e 2 \u3064\u306e\u7aef\u70b9\u3060\u3051\u3092\u7ba1\u7406\u3059\u308b\u3060\u3051\u306e\u8a71\u3060\u3002bound \u30e2\u30fc\u30c9\u3067\u306f\u30ab\u30fc\u30bd\u30eb\u304c\u884c\u672b\u306e\u6539\u884c\u306b\u3082\u4e57\u308c\u308b\u3088\u3046\u306b\u3059\u308b\u3001\u3068\u304b\u30ab\u30fc\u30bd\u30eb\uff08\u9078\u629e\u306e\u7d42\u4e86\u70b9\uff09\u304c\u9078\u629e\u306e\u958b\u59cb\u70b9\u306e\u524d\u3078\u884c\u3063\u305f\u6642\u306e\u3064\u3058\u3064\u307e\u5408\u308f\u305b\u3068\u304b\u3001\u7d30\u3005\u3068\u3057\u305f\u3082\u306e\u306f\u3042\u308b\u3051\u308c\u3069\u3001\u5185\u90e8\u7684\u306b\u306f\u7d50\u5c40\u306f 2 \u3064\u306e\u7aef\u70b9\u3060\u3002 \u4e00\u65b9\u3067\u3001vim \u3067 visual \u30e2\u30fc\u30c9\u3068\u3044\u3046\u3060\u3051\u3042\u3063\u3066\u3001\u898b\u305f\u76ee\u306e\u90e8\u5206\u304c\u91cd\u8981\u3060\u3002\u3064\u307e\u308a\u9078\u629e\u4e2d\u306e\u9818\u57df\u3092\u53cd\u8ee2\u8868\u793a\u3055\u305b\u306a\u3044\u3068\u3044\u3051\u306a\u3044\u3002DOM \u3067\u3053\u308c\u3092\u3069\u3046\u5b9f\u73fe\u3059\u308b\u304b\uff1f \u307e\u305a\u30d6\u30e9\u30a6\u30b6\u304c\u6301\u3064\u6a19\u6e96\u306e\u7bc4\u56f2\u9078\u629e\u306e\u4ed5\u7d44\u307f\u3092\u30d6\u30e9\u30a6\u30b6\u304b\u3089\u5236\u5fa1\u3059\u308b\u305f\u3081\u306b selection \u304c\u3042\u308b\u3002\u3053\u308c\u3060\u3068\u307e\u3055\u306b\u9078\u629e\u9818\u57df\u306e\u4e21\u7aef\u70b9\u3092\u6307\u5b9a\u3059\u308b\u3060\u3051\u3067\u3044\u3044\u3002 var r = window.getSelection().getRangeAt(0); r.setStart(text_node_of_lower_side, column_of_its_index); r.setEnd(text_node_of_higher_side, column_of_its_index); \u305f\u3060\u3001\u305d\u308c\u304c\u3069\u3046\u8868\u793a\u3055\u308c\u308b\u304b\u306f\u5168\u304f\u30d6\u30e9\u30a6\u30b6\u4efb\u305b\u306b\u306a\u308b\u3002\u3053\u308c\u306f\u5b9f\u969b\u697d\u306a\u306e\u3060\u3051\u3069\u3001wasavi \u5074\u306e\u30c6\u30fc\u30de\u306b\u3088\u3063\u3066\u306f\u5224\u5225\u3057\u3065\u3089\u3044\u3082\u306e\u306b\u306a\u308b\u304b\u3082\u3057\u308c\u306a\u3044\u3002 \u6b21\u306b DOM \u30ec\u30d9\u30eb\u3067\u9078\u629e\u7bc4\u56f2\u3092 span \u3067\u304f\u304f\u308a\u3060\u3059\u65b9\u6cd5\u3082\u3042\u308b\u3002\u3053\u3061\u3089\u306f\u9078\u629e\u9818\u57df\u306e\u66f4\u65b0\u3092\u81ea\u524d\u3067\u3084\u3089\u306a\u3044\u3051\u308c\u3070\u3044\u3051\u306a\u3044\u306e\u304c\u30cd\u30c3\u30af\u306b\u306a\u308b\u3002\u4e00\u756a\u7c21\u5358\u306a\u306e\u306f\u3001\u66f4\u65b0\u524d\u306b\u4e00\u65e6\u3059\u3079\u3066\u306e\u9078\u629e\u9818\u57df\u3092\u30af\u30ea\u30a2\u3057\uff08\u3064\u307e\u308a span \u3067\u304f\u304f\u308a\u3060\u3055\u308c\u305f\u90e8\u5206\u3092\u8131\u76ae\u3055\u305b\u308b\uff09\u3001\u518d\u5ea6\u9078\u629e\u7bc4\u56f2\u3092\u304f\u304f\u308a\u3060\u3059\u306e\u3067\u3042\u308b\u3002\u3053\u308c\u3060\u3068\u7279\u306b\u9078\u629e\u7bc4\u56f2\u304c\u4f55\u5341\u884c\u306b\u3082\u53ca\u3076\u5834\u5408\u306b\u660e\u3089\u304b\u306b\u9045\u304f\u306a\u308a\u305d\u3046\u3067\u306f\u3042\u308b\u306e\u3067\u3001\u5b9f\u969b\u306f\u305d\u306e\u3078\u3093\u306f\u5dee\u5206\u3067\u7ba1\u7406\u3057\u306a\u3044\u3068\u3044\u3051\u306a\u3044\u306f\u305a\u3060\u3002 \u305d\u3046\u3044\u3046\u308f\u3051\u3067\u3053\u3093\u306a\u304b\u3093\u3058\u306b\u306a\u308b\u3002\u3044\u305f\u3063\u3066\u3075\u3064\u30fc\u3002<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[5,3,4],"class_list":["post-1195","post","type-post","status-publish","format-standard","hentry","category-uncategorized","tag-javascript","tag-vi","tag-wasavi"],"_links":{"self":[{"href":"http:\/\/appsweets.net\/blog\/wp-json\/wp\/v2\/posts\/1195","targetHints":{"allow":["GET"]}}],"collection":[{"href":"http:\/\/appsweets.net\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/appsweets.net\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/appsweets.net\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"http:\/\/appsweets.net\/blog\/wp-json\/wp\/v2\/comments?post=1195"}],"version-history":[{"count":3,"href":"http:\/\/appsweets.net\/blog\/wp-json\/wp\/v2\/posts\/1195\/revisions"}],"predecessor-version":[{"id":1199,"href":"http:\/\/appsweets.net\/blog\/wp-json\/wp\/v2\/posts\/1195\/revisions\/1199"}],"wp:attachment":[{"href":"http:\/\/appsweets.net\/blog\/wp-json\/wp\/v2\/media?parent=1195"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/appsweets.net\/blog\/wp-json\/wp\/v2\/categories?post=1195"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/appsweets.net\/blog\/wp-json\/wp\/v2\/tags?post=1195"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}