如果你想要編寫一個可配置的包,你需要通過atom.config來整體讀取配置,或者通過atom.config.get來讀取一個具有命名空間的配置鍵的當(dāng)前值。
# read a value with `config.get`
@showInvisibles() if atom.config.get "editor.showInvisibles"
或者通過atom.config.observe來跟蹤任何視圖對象產(chǎn)生的修改。
{View} = require 'space-pen'
class MyView extends View
attached: ->
@fontSizeObserveSubscription =
atom.config.observe 'editor.fontSize', (newValue, {previous}) =>
@adjustFontSize()
detached: ->
@fontSizeObserveSubscription.dispose()
atom.config.observe方法會使用特定鍵路徑的當(dāng)前值立即調(diào)用提供的回調(diào)函數(shù),并且以后當(dāng)這個值發(fā)生改變時(shí)也會調(diào)用。如果你只希望在下次這個值改變的時(shí)候調(diào)用回調(diào),使用atom.config.onDidChange來代替它。
訂閱(Subscription)方法會返回一個一次性的訂閱對象。注意上面的例子中,我們?nèi)绾螌⒂嗛啽4嬖?code>@fontSizeObserveSubscription實(shí)例變量中,以及視圖被分離的時(shí)候如何處理它。你可以添加多個訂閱到[CompositeDisposable](https://atom.io/docs/api/latest/CompositeDisposable)中來將它們組合到一起。當(dāng)視圖被分離的時(shí)候你可以把它處理掉。
雖然atom.config的數(shù)據(jù)在啟動時(shí)才從~/.atom/config.cson加載,但你可以通過atom.config.set用編程的方式對其寫入。
# basic key update
atom.config.set("core.showInvisibles", true)
如果你通過特定鍵路徑來訪問包的配置,你也可能像將它們和你包里面的主模塊的schema關(guān)聯(lián)起來。更多schema的細(xì)節(jié)請閱讀配置API文檔。