tabs.moveInSuccession()

Modifies the succession relationship for a group of tabs.

使用 tabs API, a tab can be assigned a successor tab in the same window. If tab B is the successor of tab A, and tab A is closed while it is the active tab, tab B will be activated next. If tab A doesn't have a successor, then the browser is free to determine which tab to activate next. If tab B is the successor of tab A, then tab A is called a predecessor of tab B. A tab can have at most one successor, but it can have any number of predecessors. A tab cannot take itself or a tab in a different window as a successor.

All tabs start out with no successor; tabs only get a successor if assigned one by a WebExtension. However, the browser must not orphan a tab in a succession relationship with other tabs, if possible: if tab B is the successor of tab A, and tab C is the successor of tab B, and B is closed (or moved to another window), then tab A will take tab C as its successor. Preventing C from being orphaned in this way is called moving a tab (B) from its line of succession .

tabs.moveInSuccession() takes an array of tab IDs, and moves all of those tabs from their lines of succession. It then makes each tab the successor of the previous tab in the array, forming a chain. It can optionally set the successor of the last tab in the chain to an anchor tab, which is not moved from its line of succession. Additional options can control whether the tab chain is "prepended" or "appended" to the anchor tab, and whether the operation acts like a linked-list insert.

While the successor tab can be assigned with  tabs.update() , it is often desirable to use tabs.moveInSuccession() to change successors, even if only a single tab is having its successor assigned. The difference is that browser.tabs.moveInSuccession([a], b) moves tab a from its line of succession, so any predecessors of a will adopt a 's previous successor; whereas if browser.tabs.update(a, {successorTabId: b}) is used instead, tab a may continue to be the successor of other tabs, which could be unexpected. Another advantage of tabs.moveInSuccession() is that all of the succession changes happen atomically, without having to worry about races between calls to  tabs.update() and  tabs.get() and other operations like the user closing a tab.

句法

browser.tabs.moveInSuccession([1, 3, 5, 7, 2, 9], 4, {insert:true})

					

参数

tabIds

array of integer . An array of tab ID s. The order of the elements in the array defines the relationship of the tabs. Any invalid tab ID s, or tab ID s corresponding to tabs not in the same window as tabId (or the first tab in the array, if tabId is omitted), will be ignored—they will keep their current successors and predecessors.

tabId 可选

integer. ID of the tab that will be the successor of the last tab in the tabIds array. If this ID is invalid or  tabs.TAB_ID_NONE , the last tab will not have a successor. Defaults to tabs.TAB_ID_NONE .

选项 可选

对象 .

append 可选

boolean . Determines whether to move the tabs in tabIds before or after tabId in the succession. If false , the tabs are moved before tabId ,若 true , the tabs are moved after tabId 。默认为 false .

insert 可选

boolean . Determines whether to link up the current predecessors or successor (depending on options.append ) of tabId to the other side of the chain after it is prepended or appended. If true, one of the following happens: if options.append is false , the first tab in the array is set as the successor of any current predecessors of tabId ;若 options.append is true , the current successor of tabId is set as the successor of the last tab in the array. Defaults to false .

浏览器兼容性

BCD tables only load in the browser

Found a problem with this page?

最后修改: , 由 MDN 贡献者

  1. 浏览器扩展名
  2. 快速入门
    1. What are extensions?
    2. Your first extension
    3. Your second extension
    4. Anatomy of an extension
    5. Example extensions
    6. What next?
  3. 概念
    1. Using the JavaScript APIs
    2. Content scripts
    3. Match patterns
    4. Working with files
    5. 国际化
    6. Content Security Policy
    7. Native messaging
    8. Differences between API implementations
    9. Chrome incompatibilities
  4. 用户界面
    1. 用户界面
    2. Toolbar button
    3. Address bar button
    4. Sidebars
    5. Context menu items
    6. Options page
    7. Extension pages
    8. Notifications
    9. Address bar suggestions
    10. Developer tools panels
  5. 如何
    1. Intercept HTTP requests
    2. Modify a web page
    3. Insert external content
    4. Share objects with page scripts
    5. Add a button to the toolbar
    6. Implement a settings page
    7. Work with the Tabs API
    8. Work with the Bookmarks API
    9. Work with the Cookies API
    10. Work with contextual identities
    11. Interact with the clipboard
    12. Build a cross-browser extension
  6. Firefox differentiators
  7. JavaScript API
    1. Browser support for JavaScript APIs
    2. alarms
    3. bookmarks
    4. browserAction
    5. browserSettings
    6. browsingData
    7. captivePortal
    8. clipboard
    9. 命令
    10. contentScripts
    11. contextualIdentities
    12. Cookie
    13. devtools
    14. dns
    15. downloads
    16. events
    17. extension
    18. extensionTypes
    19. find
    20. history
    21. i18n
    22. identity
    23. idle
    24. management
    25. menus
    26. notifications
    27. omnibox
    28. pageAction
    29. permissions
    30. pkcs11
    31. privacy
    32. proxy
    33. runtime
    34. search
    35. sessions
    36. sidebarAction
    37. storage
    38. tabs
      1. 方法
        1. captureTab()
        2. captureVisibleTab()
        3. connect()
        4. create()
        5. detectLanguage()
        6. discard()
        7. duplicate()
        8. executeScript()
        9. get()
        10. getAllInWindow()
        11. getCurrent()
        12. getSelected()
        13. getZoom()
        14. getZoomSettings()
        15. goBack()
        16. goForward()
        17. hide()
        18. highlight()
        19. insertCSS()
        20. move()
        21. moveInSuccession()
        22. print()
        23. printPreview()
        24. query()
        25. reload()
        26. remove()
        27. removeCSS()
        28. saveAsPDF()
        29. sendMessage()
        30. sendRequest()
        31. setZoom()
        32. setZoomSettings()
        33. show()
        34. toggleReaderMode()
        35. update()
        36. warmup()
      2. 特性
        1. TAB_ID_NONE
      3. 类型
        1. MutedInfo
        2. MutedInfoReason
        3. PageSettings
        4. Tab
        5. TabStatus
        6. WindowType
        7. ZoomSettings
        8. ZoomSettingsMode
        9. ZoomSettingsScope
      4. 事件
        1. onActivated
        2. onActiveChanged
        3. onAttached
        4. onCreated
        5. onDetached
        6. onHighlightChanged
        7. onHighlighted
        8. onMoved
        9. onRemoved
        10. onReplaced
        11. onSelectionChanged
        12. onUpdated
        13. onZoomChange
    39. theme
    40. topSites
    41. 类型
    42. userScripts
    43. webNavigation
    44. webRequest
    45. windows
  8. Manifest keys
    1. 介绍
    1. 作者
    2. background
    3. browser_action
    4. browser_specific_settings
    5. chrome_settings_overrides
    6. chrome_url_overrides
    7. 命令
    8. content_scripts
    9. content_security_policy
    10. default_locale
    11. description
    12. developer
    13. devtools_page
    14. dictionaries
    15. externally_connectable
    16. homepage_url
    17. icons
    18. incognito
    19. manifest_version
    20. name
    21. offline_enabled
    22. omnibox
    23. optional_permissions
    24. options_page
    25. options_ui
    26. page_action
    27. permissions
    28. protocol_handlers
    29. short_name
    30. sidebar_action
    31. storage
    32. theme
    33. theme_experiment
    34. user_scripts
    35. version
    36. version_name
    37. web_accessible_resources
  9. Extension Workshop
    1. Develop
    2. Publish
    3. Manage
    4. Enterprise
  10. Contact us
  11. Channels
    1. Add-ons blog
    2. Add-ons forum
    3. Add-ons chat