{"id":107552,"date":"2020-11-30T19:09:45","date_gmt":"2020-11-30T10:09:45","guid":{"rendered":"http:\/\/www.key-p.com\/blog\/staff\/?p=107552"},"modified":"2020-11-30T20:43:42","modified_gmt":"2020-11-30T11:43:42","slug":"vue-grid-layout%e3%81%a7%e8%87%aa%e7%94%b1%e3%81%ab%e9%85%8d%e7%bd%ae%e3%81%a7%e3%81%8d%e3%82%8bui%e3%82%92%e4%bd%9c%e3%82%8b","status":"publish","type":"post","link":"https:\/\/www.key-p.com\/blog\/staff\/archives\/107552","title":{"rendered":"vue-grid-layout\u3067\u81ea\u7531\u306b\u914d\u7f6e\u3067\u304d\u308bUI\u3092\u4f5c\u308b"},"content":{"rendered":"<p>\n\u6e9d\u7551\u3067\u3059\u3002<br \/>\nKP\u5185\u3067\u306f\u73cd\u3057\u304f\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u3070\u304b\u308a\u89e6\u3063\u3066\u308b\u4eba\u9593\u3067\u3059\u3002<br \/>\n<br \/>\n\u958b\u767a\u30d6\u30ed\u30b0\u3092\u66f8\u304f\u306e\u306f\u4e45\u3005\u3002<br \/>\n\u30cd\u30bf\u306f\u306a\u3044\u3053\u3068\u306a\u3044\u3093\u3067\u3059\u3051\u3069\u3001\u306a\u304b\u306a\u304b\u66f8\u304f\u307e\u3067\u3044\u304b\u306a\u3044\u3002\u3002\u3002<br \/>\n\u524d\u56de\u306fVim\u306e\u30c6\u30ad\u30b9\u30c8\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u30cd\u30bf\u3067\u3057\u305f\u3063\u3051\u30fb\u30fb\u30fb\uff1f<br \/>\n<br \/>\n\u4eca\u56de\u306fVue\u306e\u304a\u8a71\u3067\u3059\u3002\u591a\u5206\u3053\u3053\u3067\u66f8\u304f\u306e\u306f\u521d\u3081\u3066\u3060\u3068\u601d\u3044\u307e\u3059\u3002<br \/>\n<br \/>\n\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u3042\u308b\u3042\u308b\u3060\u3068\u601d\u3046\u3093\u3067\u3059\u304c\u3001Chrome\u306e\u62e1\u5f35\u3067React\u3068\u304bVue\u306e\u3092\u5165\u308c\u3066\u3044\u308b\u95a2\u4fc2\u3067\u3001<br \/>\n\u300c\u3042\u3063\u3001\u3053\u306e\u30b5\u30fc\u30d3\u30b9\u306f\u3053\u306eFW\u4f7f\u3063\u3066\u308b\u3093\u3060\uff01\u300d\u3063\u3066\u3044\u3046\u3084\u3064\u3002<br \/>\ndev-tool\u958b\u3044\u3066\u3001Element\u898b\u306a\u304c\u3089\u300c\u3053\u306eclass\u540d\u306a\u3093\u3060\u308d\u3046\uff1f\u300d\u307f\u305f\u3044\u306a\u3053\u3068\u3092\u3057\u3066\u3001<br \/>\n\u4f7f\u3063\u3066\u308b\u30e9\u30a4\u30d6\u30e9\u30ea\u3084\u30d7\u30e9\u30b0\u30a4\u30f3\u3092\u7279\u5b9a\u3057\u3066\u81ea\u5206\u3067\u3082\u8a66\u3057\u3066\u307f\u305f\u308a\u3002<br \/>\n<br \/>\n\u305d\u3093\u306a\u3053\u3093\u306a\u3067\u89e6\u3063\u3066\u307f\u305fvue-grid-layout\u306e\u304a\u8a71\u3067\u3059\u3002<br \/>\n<br \/>\n<h4>vue-grid-layout<\/h4>\n<a target=\"_blank\" href=\"https:\/\/github.com\/jbaysolutions\/vue-grid-layout\">vue-grid-layout<\/a>\u306f\u3001React-Grid-Layout\u306b\u30a4\u30f3\u30b9\u30d1\u30a4\u30a2\u3055\u308c\u3066\u4f5c\u3089\u308c\u3066\u3044\u308b\u3082\u306e\u3067\u3059\u3002<br \/>\n<br \/>\n<a target=\"_blank\" href=\"http:\/\/dsmorse.github.io\/gridster.js\/\">Gridster.js<\/a>\u30e9\u30a4\u30af\u306a\u3082\u306e\u3067\u3001\u81ea\u7531\u306b\u30c9\u30e9\u30c3\u30b0\u3057\u3066\u30b3\u30f3\u30c6\u30f3\u30c4\u306e\u5927\u304d\u3055\u3092\u5909\u3048\u305f\u308a\u3001\u914d\u7f6e\u3092\u5909\u3048\u305f\u308a\u3059\u308bUI\u304c\u7c21\u5358\u306b\u4f5c\u308c\u307e\u3059\u3002<br \/>\n<br \/>\n\u65e9\u901f\u30b5\u30f3\u30d7\u30eb\u898b\u3066\u3044\u304d\u307e\u3057\u3087\u3046\u3002<br \/>\n<br \/>\n<h4>\u57fa\u672c<\/h4>\n\u6b63\u76f4\u3001Document\u306eExamples\u898b\u305f\u65b9\u304c\u65e9\u3044\u306e\u3067\u3001<a target=\"_blank\" href=\"https:\/\/jbaysolutions.github.io\/vue-grid-layout\/guide\/01-basic.html\">Examples<\/a>\u53c2\u7167\u3057\u3066\u304f\u3060\u3055\u3044\u3002\u3002\u3002<br \/>\n <br \/>\n<pre class=\"lang:xhtml decode:true \" >&lt;div id=\"app\"&gt;\n  &lt;grid-layout \n    :layout.sync=\"layout\"\n    :col-num=\"12\"\n    :row-height=\"30\"\n    :is-draggable=\"true\"\n    :is-resizable=\"true\"\n    :vertical-compact=\"true\"\n    :use-css-transforms=\"true\"\n  &gt;\n    &lt;grid-item \n      v-for=\"item in layout\"\n      :x=\"item.x\"\n      :y=\"item.y\"\n      :w=\"item.w\"\n      :h=\"item.h\"\n      :i=\"item.i\"\n    &gt;\n      {{ item.i }}\n    &lt;\/grid-item&gt;\n  &lt;\/grid-layout&gt;\n&lt;\/div&gt;\n<\/pre>\n<pre class=\"lang:js decode:true \" >const layout = [\n  { x:0, y:0, w:2, h:2, i:\"0\" },\n  { x:2, y:0, w:2, h:4, i:\"1\" },\n  { x:4, y:0, w:2, h:5, i:\"2\" }\n]\n\nnew Vue({\n  el: \"#app\",\n  data() {\n    return {\n      layout\n    }\n  }\n})<\/pre>\n\u3053\u308c\u3060\u3051\u3067\u30c9\u30e9\u30c3\u30b0\u3057\u3066\u52d5\u304b\u3057\u3066\u3001\u5927\u304d\u3055\u3082\u5909\u3048\u3089\u308c\u308bUI\u304c\u4f5c\u308c\u307e\u3059\u3002<br \/>\n\u7c21\u5358\u3067\u3059\u306d\u3002<br \/>\njsfiddle -> <a target=\"_blank\" href=\"https:\/\/jsfiddle.net\/kohei_mizobata\/nuktder5\/14\/\">vue-grid-layout sample<\/a><br \/>\nFiddle\u7f6e\u3044\u3066\u304a\u304f\u306e\u3067\u3001\u89e6\u3063\u3066\u3001\u30b3\u30fc\u30c9\u3044\u3058\u3063\u3066\u904a\u3093\u3067\u307f\u3066\u304f\u3060\u3055\u3044\u3002<br \/>\n<br \/>\n<h4>\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e\u63cf\u753b<\/h4>\n\u5b9f\u969b\u306b\u3053\u308c\u3092\u4f7f\u3063\u3066\u3044\u304f\u3068\u3059\u308b\u3068\u3001grid-item\u306e\u4e2d\u306b\u306f\u5404\u7a2e\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u304c\u5165\u3063\u3066\u304f\u308b\u306f\u305a\u3067\u3059\u3002<br \/>\n1\u3064\u306e\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3092v-for\u3067\u30eb\u30fc\u30d7\u3057\u3066\u63cf\u753b\u3059\u308b\u306e\u3067\u3042\u308c\u3070\u3001grid-item\u306e\u4e2d\u3067\u3001\u305d\u306e\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3092\u66f8\u3051\u3070OK\u3067\u3059\u3002<br \/>\n(\u4ee5\u4e0b\u3001\u8aac\u660e\u7528\u306bprops\u7701\u7565\u3057\u3066\u66f8\u3044\u3066\u3044\u304d\u307e\u3059)<br \/>\n<pre class=\"lang:xhtml decode:true \" >&lt;grid-layout&gt;\n  &lt;grid-item v-for=\"item in layout\"&gt;\n    &lt;hoge-component\/&gt;\n  &lt;\/grid-item&gt;\n&lt;\/grid-layout&gt;<\/pre>\n\u3067\u3059\u304c\u3001\u3053\u306e\u30d1\u30bf\u30fc\u30f3\u306f\u307b\u3068\u3093\u3069\u306a\u304f\u3066\u3001\u305d\u308c\u305e\u308c\u306egrid-item\u306b\u306f\u5225\u306e\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3092\u63cf\u753b\u3057\u305f\u3044\u306f\u305a\u3002<br \/>\n<br \/>\nVue\u306b\u306f\u52d5\u7684\u306a\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e\u63cf\u753b\u65b9\u6cd5\u304c\u3042\u308a\u307e\u3059\u3002<br \/>\n<a target=\"_blank\" href=\"https:\/\/jp.vuejs.org\/v2\/guide\/components.html#%E5%8B%95%E7%9A%84%E3%81%AA%E3%82%B3%E3%83%B3%E3%83%9D%E3%83%BC%E3%83%8D%E3%83%B3%E3%83%88\">\u52d5\u7684\u306a\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8<\/a><br \/>\n<br \/>\n <br \/>\n<pre class=\"lang:xhtml decode:true \" >&lt;grid-layout&gt;\n  &lt;grid-item v-for=\"item in layout\"&gt;\n    &lt;component :is=\"item.i\"\/&gt;\n  &lt;\/grid-item&gt;\n&lt;\/grid-layout&gt;<\/pre>\n<pre class=\"lang:js decode:true \" >import FooComponent from 'Foo.vue'\nimport HogeComponent from 'Hoge.vue'\nimport PiyoComponent from 'Piyo.vue'\n\nconst layout = [\n  { x:0, y:0, w:2, h:2, i:\"FooComponent\" },\n  { x:2, y:0, w:2, h:4, i:\"HogeComponent\" },\n  { x:4, y:0, w:2, h:5, i:\"PiyoComponent\" }\n]\n\nnew Vue({\n  el: \"#app\",\n  components: {\n    FooComponent,\n    HogeComponent,\n    PiyoComponent\n  },\n  data() {\n    return {\n      layout\n    }\n  }\n})<\/pre>\nlayout\u306ei\u306b\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u540d\u3092\u66f8\u3044\u3066\u304a\u304d\u3001:is\u306b\u5165\u308c\u3066\u3042\u3052\u308b\u3068\u7c21\u5358\u3067\u3059\u3002<br \/>\n<br \/>\n<h4>\u30ec\u30a4\u30a2\u30a6\u30c8\u306e\u4fdd\u6301<\/h4>\n\"\u30ec\u30a4\u30a2\u30a6\u30c8\u306e\u4fdd\u6301\"\u306f\u3001\u3053\u306e\u624b\u306eUI\u3092\u63d0\u4f9b\u3059\u308b\u3068\u3001\u5fc5\u305a\u8981\u671b\u3068\u3057\u3066\u4e0a\u304c\u3063\u3066\u304f\u308b\u3067\u3057\u3087\u3046\u3002<br \/>\n\u5b9f\u73fe\u65b9\u6cd5\u3068\u3057\u3066\u306f\u5358\u7d14\u3067\u3001layout-updated\u30a4\u30d9\u30f3\u30c8\u3067localStorage\u306blayout\u3092\u4fdd\u6301\u3057\u3066\u3042\u3052\u308c\u3070OK\u3067\u3059\u3002<br \/>\n <br \/>\n<pre class=\"lang:xhtml decode:true \" >&lt;grid-layout @layout-updated=\"layoutUpdated\"&gt;\n  &lt;!-- html... ---&gt;\n&lt;\/grid-layout&gt;<\/pre>\n<pre class=\"lang:js decode:true \" >const defaultLayout = [\n  \/\/ layout\n]\n\nnew Vue({\n  el: \"#app\",\n  data() {\n    return {\n      layout: defaultLayout\n    }\n  },\n\n  created() {\n    if (localStorage.getItem('app-layout')) {\n      this.layout = JSON.parse(localStorage.getItem('app-layout'))\n    } else {\n      this.layout = defaultLayout\n    }\n  },\n\n  methods: {\n    layoutUpdated(newLayout) {\n      localStorage.setItem('app-layout', JSON.stringify(newLayout))\n    }\n  }\n})<\/pre>\n\u3053\u3093\u306a\u30a4\u30e1\u30fc\u30b8\u3067\u3059\u3002<br \/>\n<br \/>\n<h4>\u307e\u3068\u3081<\/h4>\nvue-grid-layout\u3092\u4f7f\u3046\u3068\u3001\u7c21\u5358\u306b\u3053\u306e\u3088\u3046\u306aUI\u304c\u4f5c\u308c\u307e\u3059\u3002<br \/>\n<br \/>\n\u4f7f\u3063\u3066\u307f\u3066\u306e\u611f\u60f3\u3067\u3059\u304c\u3001\u30b5\u30a4\u30ba\u3092\u5909\u3048\u3089\u308c\u308b\u3068\u3044\u3046\u7279\u6027\u4e0a\u3001\u4e2d\u306b\u63cf\u753b\u3059\u308b\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306f\u3001<br \/>\n\u3042\u308b\u7a0b\u5ea6\u30b5\u30a4\u30ba\u306e\u5909\u66f4\u306b\u8010\u3048\u3089\u308c\u308b\u3088\u3046\u306b\u3059\u308b\u5fc5\u8981\u304c\u751f\u3058\u308b\u306a\u3068\u3044\u3046\u5370\u8c61\u3067\u3059\u3002<br \/>\n\u7d30\u304b\u304f\u30ec\u30a4\u30a2\u30a6\u30c8\u3092\u6307\u5b9a\u3055\u308c\u308b\u3088\u3046\u306a\u6848\u4ef6\u3060\u3068\u3001\u9006\u306b\u9762\u5012\u306a\u3053\u3068\u306b\u306a\u308b\u304b\u3082\u3057\u308c\u307e\u305b\u3093\u3002<br \/>\n\u3056\u3063\u304f\u308a\u3067\u826f\u3051\u308c\u3070\u3001display: flex\u3068flex-wrap: wrap\u3067\u3069\u3046\u306b\u304b\u306a\u308b\u304b\u3082\u3057\u308c\u307e\u305b\u3093\u304c\u30fb\u30fb\u30fb\u3002<br \/>\n<br \/>\n\u30b0\u30e9\u30d5(Highcharts)\u3084\u5730\u56f3(OpenLayers)\u306a\u3069\u3092\u63cf\u753b\u3057\u3066\u3044\u308b\u5834\u5408\u306f\u3001resized\u306e\u30bf\u30a4\u30df\u30f3\u30b0\u3067\u3001\u305d\u308c\u81ea\u4f53\u306e\u30b5\u30a4\u30ba\u3092\u5909\u66f4\u3059\u308b\u5fc5\u8981\u3082\u3042\u308a\u307e\u3059\u3002<br \/>\ngrid-item\u81ea\u4f53\u306e\u30b5\u30a4\u30ba\u3092\u3068\u3063\u3066\u30fb\u30fb\u30fbresize\u3092\u304b\u3051\u308b\u3088\u3046\u306a\u30a4\u30e1\u30fc\u30b8\u3002<br \/>\n<br \/>\n\u4f7f\u3044\u59cb\u3081\u3066\u9593\u3082\u306a\u3044\u306e\u3067\u3001Tips\u304c\u305f\u307e\u308c\u3070\u307e\u305f\u66f8\u304d\u307e\u3059\u3002<br \/>\n<br \/>\n\u305d\u308c\u3067\u306f\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u6e9d\u7551\u3067\u3059\u3002 KP\u5185\u3067\u306f\u73cd\u3057\u304f\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u3070\u304b\u308a\u89e6\u3063\u3066\u308b\u4eba\u9593\u3067\u3059\u3002 \u958b\u767a\u30d6\u30ed\u30b0\u3092 &hellip; <a href=\"https:\/\/www.key-p.com\/blog\/staff\/archives\/107552\">\u7d9a\u304d\u3092\u8aad\u3080 <span class=\"meta-nav\">&rarr;<\/span><\/a><\/p>\n","protected":false},"author":33,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":[],"categories":[16],"tags":[],"jetpack-related-posts":[],"_links":{"self":[{"href":"https:\/\/www.key-p.com\/blog\/staff\/wp-json\/wp\/v2\/posts\/107552"}],"collection":[{"href":"https:\/\/www.key-p.com\/blog\/staff\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.key-p.com\/blog\/staff\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.key-p.com\/blog\/staff\/wp-json\/wp\/v2\/users\/33"}],"replies":[{"embeddable":true,"href":"https:\/\/www.key-p.com\/blog\/staff\/wp-json\/wp\/v2\/comments?post=107552"}],"version-history":[{"count":13,"href":"https:\/\/www.key-p.com\/blog\/staff\/wp-json\/wp\/v2\/posts\/107552\/revisions"}],"predecessor-version":[{"id":107565,"href":"https:\/\/www.key-p.com\/blog\/staff\/wp-json\/wp\/v2\/posts\/107552\/revisions\/107565"}],"wp:attachment":[{"href":"https:\/\/www.key-p.com\/blog\/staff\/wp-json\/wp\/v2\/media?parent=107552"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.key-p.com\/blog\/staff\/wp-json\/wp\/v2\/categories?post=107552"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.key-p.com\/blog\/staff\/wp-json\/wp\/v2\/tags?post=107552"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}