button.html 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641
  1. ---
  2. layout: documentation
  3. doc-tab: elements
  4. doc-subtab: button
  5. variables:
  6. - name: $button-color
  7. value: $grey-darker
  8. - name: $button-background-color
  9. value: $white
  10. - name: $button-border-color
  11. value: $grey-lighter
  12. - name: $button-hover-color
  13. value: $link-hover
  14. - name: $button-hover-border-color
  15. value: $link-hover-border
  16. - name: $button-focus-color
  17. value: $link-focus
  18. - name: $button-focus-border-color
  19. value: $link-focus-border
  20. - name: $button-active-color
  21. value: $link-active
  22. - name: $button-active-border-color
  23. value: $link-active-border
  24. - name: $button-link-color
  25. value: $text
  26. - name: $button-link-hover-background-color
  27. value: $background
  28. - name: $button-link-hover-color
  29. value: $text-strong
  30. - name: $button-disabled-background-color
  31. value: $white
  32. - name: $button-disabled-border-color
  33. value: $grey-lighter
  34. - name: $button-disabled-shadow
  35. value: none
  36. - name: $button-disabled-opacity
  37. value: 0.5
  38. - name: $button-static-color
  39. value: $grey
  40. - name: $button-static-background-color
  41. value: $white-ter
  42. - name: $button-static-border-color
  43. value: $grey-lighter
  44. - name: $button-shadow-inset
  45. value: inset 0 1px 2px rgba($black, 0.2)
  46. ---
  47. {% include subnav-elements.html %}
  48. <section class="section">
  49. <div class="container">
  50. <h1 class="title">Buttons</h1>
  51. <h2 class="subtitle">
  52. The classic <strong>button</strong>, in different colors, sizes, and states
  53. </h2>
  54. <hr>
  55. {% capture button_example %}
  56. <div class="block">
  57. <a class="button">Button</a>
  58. <a class="button is-white">White</a>
  59. <a class="button is-light">Light</a>
  60. <a class="button is-dark">Dark</a>
  61. <a class="button is-black">Black</a>
  62. <a class="button is-link">Link</a>
  63. </div>
  64. <div class="block">
  65. <a class="button is-primary">Primary</a>
  66. <a class="button is-info">Info</a>
  67. <a class="button is-success">Success</a>
  68. <a class="button is-warning">Warning</a>
  69. <a class="button is-danger">Danger</a>
  70. </div>
  71. {% endcapture %}
  72. <div class="columns">
  73. <div class="column">
  74. {{button_example}}
  75. </div>
  76. <div class="column">
  77. {% highlight html %}
  78. {{button_example}}
  79. {% endhighlight %}
  80. </div>
  81. </div>
  82. <hr>
  83. <h3 class="title">Sizes</h3>
  84. {% capture button_sizes_example %}
  85. <a class="button is-small">Small</a>
  86. <a class="button">Normal</a>
  87. <a class="button is-medium">Medium</a>
  88. <a class="button is-large">Large</a>
  89. {% endcapture %}
  90. <div class="columns">
  91. <div class="column">
  92. {{button_sizes_example}}
  93. </div>
  94. <div class="column">
  95. {% highlight html %}
  96. {{button_sizes_example}}
  97. {% endhighlight %}
  98. </div>
  99. </div>
  100. <hr>
  101. <h3 class="title">Styles</h3>
  102. <h4 class="subtitle">Outlined</h4>
  103. {% capture button_outlined_example %}
  104. <a class="button is-outlined">Outlined</a>
  105. <a class="button is-primary is-outlined">Outlined</a>
  106. <a class="button is-info is-outlined">Outlined</a>
  107. <a class="button is-success is-outlined">Outlined</a>
  108. <a class="button is-danger is-outlined">Outlined</a>
  109. {% endcapture %}
  110. <div class="columns">
  111. <div class="column">
  112. {{button_outlined_example}}
  113. </div>
  114. <div class="column">
  115. {% highlight html %}
  116. {{button_outlined_example}}
  117. {% endhighlight %}
  118. </div>
  119. </div>
  120. <h4 class="subtitle">Inverted (the text color becomes the background color, and vice-versa)</h4>
  121. {% capture button_inverted_example %}
  122. <a class="button is-primary is-inverted">Inverted</a>
  123. <a class="button is-info is-inverted">Inverted</a>
  124. <a class="button is-success is-inverted">Inverted</a>
  125. <a class="button is-danger is-inverted">Inverted</a>
  126. {% endcapture %}
  127. <div class="columns">
  128. <div class="column">
  129. <div class="callout is-primary">
  130. {{button_inverted_example}}
  131. </div>
  132. </div>
  133. <div class="column">
  134. {% highlight html %}
  135. {{button_inverted_example}}
  136. {% endhighlight %}
  137. </div>
  138. </div>
  139. <h4 class="subtitle">Invert Outlined (the invert color becomes the text and border colors)</h4>
  140. {% capture button_inverted_outlined_example %}
  141. <a class="button is-primary is-inverted is-outlined">Invert Outlined</a>
  142. <a class="button is-info is-inverted is-outlined">Invert Outlined</a>
  143. <a class="button is-success is-inverted is-outlined">Invert Outlined</a>
  144. <a class="button is-danger is-inverted is-outlined">Invert Outlined</a>
  145. {% endcapture %}
  146. <div class="columns">
  147. <div class="column">
  148. <div class="callout is-primary">
  149. {{button_inverted_outlined_example}}
  150. </div>
  151. </div>
  152. <div class="column">
  153. {% highlight html %}
  154. {{button_inverted_outlined_example}}
  155. {% endhighlight %}
  156. </div>
  157. </div>
  158. <hr>
  159. <h3 class="title">States</h3>
  160. <h4 class="subtitle">Normal</h4>
  161. {% capture button_normal_example %}
  162. <a class="button">Normal</a>
  163. <a class="button is-primary">Normal</a>
  164. <a class="button is-info">Normal</a>
  165. <a class="button is-success">Normal</a>
  166. <a class="button is-warning">Normal</a>
  167. <a class="button is-danger">Normal</a>
  168. {% endcapture %}
  169. <div class="columns">
  170. <div class="column">
  171. {{button_normal_example}}
  172. </div>
  173. <div class="column">
  174. {% highlight html %}
  175. {{button_normal_example}}
  176. {% endhighlight %}
  177. </div>
  178. </div>
  179. <h4 class="subtitle">Hover</h4>
  180. {% capture button_hover_example %}
  181. <a class="button is-hovered">Hover</a>
  182. <a class="button is-primary is-hovered">Hover</a>
  183. <a class="button is-info is-hovered">Hover</a>
  184. <a class="button is-success is-hovered">Hover</a>
  185. <a class="button is-warning is-hovered">Hover</a>
  186. <a class="button is-danger is-hovered">Hover</a>
  187. {% endcapture %}
  188. <div class="columns">
  189. <div class="column">
  190. {{button_hover_example}}
  191. </div>
  192. <div class="column">
  193. {% highlight html %}
  194. {{button_hover_example}}
  195. {% endhighlight %}
  196. </div>
  197. </div>
  198. <h4 class="subtitle">Focus</h4>
  199. {% capture button_focus_example %}
  200. <a class="button is-focused">Focus</a>
  201. <a class="button is-primary is-focused">Focus</a>
  202. <a class="button is-info is-focused">Focus</a>
  203. <a class="button is-success is-focused">Focus</a>
  204. <a class="button is-warning is-focused">Focus</a>
  205. <a class="button is-danger is-focused">Focus</a>
  206. {% endcapture %}
  207. <div class="columns">
  208. <div class="column">
  209. {{button_focus_example}}
  210. </div>
  211. <div class="column">
  212. {% highlight html %}
  213. {{button_focus_example}}
  214. {% endhighlight %}
  215. </div>
  216. </div>
  217. <h4 class="subtitle">Active</h4>
  218. {% capture button_active_example %}
  219. <a class="button is-active">Active</a>
  220. <a class="button is-primary is-active">Active</a>
  221. <a class="button is-info is-active">Active</a>
  222. <a class="button is-success is-active">Active</a>
  223. <a class="button is-warning is-active">Active</a>
  224. <a class="button is-danger is-active">Active</a>
  225. {% endcapture %}
  226. <div class="columns">
  227. <div class="column">
  228. {{button_active_example}}
  229. </div>
  230. <div class="column">
  231. {% highlight html %}
  232. {{button_active_example}}
  233. {% endhighlight %}
  234. </div>
  235. </div>
  236. <h4 class="subtitle">Loading</h4>
  237. {% capture button_loading_example %}
  238. <a class="button is-loading">Loading</a>
  239. <a class="button is-primary is-loading">Loading</a>
  240. <a class="button is-info is-loading">Loading</a>
  241. <a class="button is-success is-loading">Loading</a>
  242. <a class="button is-warning is-loading">Loading</a>
  243. <a class="button is-danger is-loading">Loading</a>
  244. {% endcapture %}
  245. <div class="columns">
  246. <div class="column">
  247. {{button_loading_example}}
  248. </div>
  249. <div class="column">
  250. {% highlight html %}
  251. {{button_loading_example}}
  252. {% endhighlight %}
  253. </div>
  254. </div>
  255. <h4 id="static-button" class="subtitle">
  256. Static
  257. </h4>
  258. {% capture button_static_example %}
  259. <span class="button is-static">Static</span>
  260. {% endcapture %}
  261. <div class="columns">
  262. <div class="column">
  263. <div class="content">
  264. <p>
  265. <span class="tag is-success">New!</span>
  266. <span class="tag is-info">0.4.2</span>
  267. </p>
  268. <p>
  269. You can create a <strong>non-interactive button</strong> by using the <code>is-static</code> modifier. This is useful to align a text label with an input, for example when using <a href="{{site.url}}/documentation/form/general#form-addons">form addons</a>.
  270. </p>
  271. </div>
  272. {{button_static_example}}
  273. </div>
  274. <div class="column">
  275. {% highlight html %}
  276. {{button_static_example}}
  277. {% endhighlight %}
  278. </div>
  279. </div>
  280. <h4 class="subtitle">Disabled</h4>
  281. {% capture button_disabled_example %}
  282. <a class="button" title="Disabled button" disabled>Disabled</a>
  283. <a class="button is-primary" title="Disabled button" disabled>Disabled</a>
  284. <a class="button is-info" title="Disabled button" disabled>Disabled</a>
  285. <a class="button is-success" title="Disabled button" disabled>Disabled</a>
  286. <a class="button is-warning" title="Disabled button" disabled>Disabled</a>
  287. <a class="button is-danger" title="Disabled button" disabled>Disabled</a>
  288. {% endcapture %}
  289. <div class="columns">
  290. <div class="column">
  291. <div class="block">{{button_disabled_example}}</div>
  292. <div class="message is-danger">
  293. <div class="message-body">
  294. <p>The <code>is-disabled</code> CSS class has been deprecated in favor of the <code>disabled</code> HTML attribute. <a href="https://github.com/jgthms/bulma/issues/276">Learn more</a></p>
  295. </div>
  296. </div>
  297. </div>
  298. <div class="column">
  299. {% highlight html %}
  300. {{button_disabled_example}}
  301. {% endhighlight %}
  302. </div>
  303. </div>
  304. <h4 class="subtitle">With Font Awesome icons</h4>
  305. {% capture button_fa_example %}
  306. <p class="field">
  307. <a class="button">
  308. <span class="icon is-small">
  309. <i class="fa fa-bold"></i>
  310. </span>
  311. </a>
  312. <a class="button">
  313. <span class="icon is-small">
  314. <i class="fa fa-italic"></i>
  315. </span>
  316. </a>
  317. <a class="button">
  318. <span class="icon is-small">
  319. <i class="fa fa-underline"></i>
  320. </span>
  321. </a>
  322. </p>
  323. <p class="field">
  324. <a class="button">
  325. <span class="icon">
  326. <i class="fa fa-github"></i>
  327. </span>
  328. <span>GitHub</span>
  329. </a>
  330. <a class="button is-primary">
  331. <span class="icon">
  332. <i class="fa fa-twitter"></i>
  333. </span>
  334. <span>Twitter</span>
  335. </a>
  336. <a class="button is-success">
  337. <span class="icon is-small">
  338. <i class="fa fa-check"></i>
  339. </span>
  340. <span>Save</span>
  341. </a>
  342. <a class="button is-danger is-outlined">
  343. <span>Delete</span>
  344. <span class="icon is-small">
  345. <i class="fa fa-times"></i>
  346. </span>
  347. </a>
  348. </p>
  349. <p class="field">
  350. <a class="button is-small">
  351. <span class="icon is-small">
  352. <i class="fa fa-github"></i>
  353. </span>
  354. <span>GitHub</span>
  355. </a>
  356. <a class="button">
  357. <span class="icon">
  358. <i class="fa fa-github"></i>
  359. </span>
  360. <span>GitHub</span>
  361. </a>
  362. <a class="button is-medium">
  363. <span class="icon">
  364. <i class="fa fa-github"></i>
  365. </span>
  366. <span>GitHub</span>
  367. </a>
  368. <a class="button is-large">
  369. <span class="icon is-medium">
  370. <i class="fa fa-github"></i>
  371. </span>
  372. <span>GitHub</span>
  373. </a>
  374. </p>
  375. {% endcapture %}
  376. <div class="columns">
  377. <div class="column">
  378. {{button_fa_example}}
  379. </div>
  380. <div class="column">
  381. {% highlight html %}
  382. {{button_fa_example}}
  383. {% endhighlight %}
  384. </div>
  385. </div>
  386. <div class="columns">
  387. <div class="column">
  388. <div class="content">
  389. <p>
  390. <span class="tag is-success">New!</span>
  391. </p>
  392. <p>
  393. If the button only contains an icon, Bulma will make sure the button remains <strong>square</strong>, no matter the size of the button <em>or</em> of the icon.
  394. </p>
  395. </div>
  396. {% capture button_only_icon_example %}
  397. <p class="field">
  398. <a class="button is-small">
  399. <span class="icon is-small">
  400. <i class="fa fa-header"></i>
  401. </span>
  402. </a>
  403. </p>
  404. <p class="field">
  405. <a class="button">
  406. <span class="icon is-small">
  407. <i class="fa fa-header"></i>
  408. </span>
  409. </a>
  410. <a class="button">
  411. <span class="icon">
  412. <i class="fa fa-header"></i>
  413. </span>
  414. </a>
  415. </p>
  416. <p class="field">
  417. <a class="button is-medium">
  418. <span class="icon is-small">
  419. <i class="fa fa-header"></i>
  420. </span>
  421. </a>
  422. <a class="button is-medium">
  423. <span class="icon">
  424. <i class="fa fa-header"></i>
  425. </span>
  426. </a>
  427. <a class="button is-medium">
  428. <span class="icon is-medium">
  429. <i class="fa fa-header"></i>
  430. </span>
  431. </a>
  432. </p>
  433. <p class="field">
  434. <a class="button is-large">
  435. <span class="icon is-small">
  436. <i class="fa fa-header"></i>
  437. </span>
  438. </a>
  439. <a class="button is-large">
  440. <span class="icon">
  441. <i class="fa fa-header"></i>
  442. </span>
  443. </a>
  444. <a class="button is-large">
  445. <span class="icon is-medium">
  446. <i class="fa fa-header"></i>
  447. </span>
  448. </a>
  449. <a class="button is-large">
  450. <span class="icon is-large">
  451. <i class="fa fa-header"></i>
  452. </span>
  453. </a>
  454. </p>
  455. {% endcapture %}
  456. {{button_only_icon_example}}
  457. </div>
  458. <div class="column">
  459. {% highlight html %}
  460. {{button_only_icon_example}}
  461. {% endhighlight %}
  462. </div>
  463. </div>
  464. <hr>
  465. <h3 class="title">Button group</h3>
  466. <div class="content">
  467. <p>If you want to <strong>group</strong> buttons together, use the <code>is-grouped</code> modifier on the <code>field</code> container:</p>
  468. </div>
  469. {% capture button_group_example %}
  470. <div class="field is-grouped">
  471. <p class="control">
  472. <a class="button is-primary">
  473. Save changes
  474. </a>
  475. </p>
  476. <p class="control">
  477. <a class="button">
  478. Cancel
  479. </a>
  480. </p>
  481. <p class="control">
  482. <a class="button is-danger">
  483. Delete post
  484. </a>
  485. </p>
  486. </div>
  487. {% endcapture %}
  488. <div class="example">
  489. {{button_group_example}}
  490. </div>
  491. {% highlight html %}
  492. {{button_group_example}}
  493. {% endhighlight %}
  494. <hr>
  495. <h3 class="title">Button addons</h3>
  496. <div class="content">
  497. <p>If you want to use buttons as <strong>addons</strong>, use the <code>has-addons</code> modifier on the <code>field</code> container:</p>
  498. </div>
  499. {% capture button_addons_example %}
  500. <div class="field has-addons">
  501. <p class="control">
  502. <a class="button">
  503. <span class="icon is-small">
  504. <i class="fa fa-align-left"></i>
  505. </span>
  506. <span>Left</span>
  507. </a>
  508. </p>
  509. <p class="control">
  510. <a class="button">
  511. <span class="icon is-small">
  512. <i class="fa fa-align-center"></i>
  513. </span>
  514. <span>Center</span>
  515. </a>
  516. </p>
  517. <p class="control">
  518. <a class="button">
  519. <span class="icon is-small">
  520. <i class="fa fa-align-right"></i>
  521. </span>
  522. <span>Right</span>
  523. </a>
  524. </p>
  525. </div>
  526. {% endcapture %}
  527. <div class="example">
  528. {{button_addons_example}}
  529. </div>
  530. {% highlight html %}
  531. {{button_addons_example}}
  532. {% endhighlight %}
  533. <hr>
  534. <h3 class="title">Button group with addons</h3>
  535. <div class="content">
  536. <p>You can group together addons as well:</p>
  537. </div>
  538. {% capture button_group_addons_example %}
  539. <div class="field has-addons">
  540. <p class="control">
  541. <a class="button">
  542. <span class="icon is-small">
  543. <i class="fa fa-bold"></i>
  544. </span>
  545. <span>Bold</span>
  546. </a>
  547. </p>
  548. <p class="control">
  549. <a class="button">
  550. <span class="icon is-small">
  551. <i class="fa fa-italic"></i>
  552. </span>
  553. <span>Italic</span>
  554. </a>
  555. </p>
  556. <p class="control">
  557. <a class="button">
  558. <span class="icon is-small">
  559. <i class="fa fa-underline"></i>
  560. </span>
  561. <span>Underline</span>
  562. </a>
  563. </p>
  564. </div>
  565. <div class="field has-addons">
  566. <p class="control">
  567. <a class="button">
  568. <span class="icon is-small">
  569. <i class="fa fa-align-left"></i>
  570. </span>
  571. <span>Left</span>
  572. </a>
  573. </p>
  574. <p class="control">
  575. <a class="button">
  576. <span class="icon is-small">
  577. <i class="fa fa-align-center"></i>
  578. </span>
  579. <span>Center</span>
  580. </a>
  581. </p>
  582. <p class="control">
  583. <a class="button">
  584. <span class="icon is-small">
  585. <i class="fa fa-align-right"></i>
  586. </span>
  587. <span>Right</span>
  588. </a>
  589. </p>
  590. </div>
  591. {% endcapture %}
  592. <div class="example">
  593. {{button_group_addons_example}}
  594. </div>
  595. {% highlight html %}
  596. {{button_group_addons_example}}
  597. {% endhighlight %}
  598. {% include variables.html %}
  599. </div>
  600. </section>