gpt4 book ai didi

javascript - 如何将 $state 变量传递给其他 2 个同级 $states?

转载 作者:塔克拉玛干 更新时间:2023-11-02 20:41:50 25 4
gpt4 key购买 nike

公众号:https://plnkr.co/edit/Brmcxd2LjGVJ6DXwuJtF?p=preview

架构:

$login -> $container (包含 $dashboard$feed ),dashboard包含:$tickers , $tags , $viewHeader$socialMedia组件。

目标:

tags需要通信并将标记对象发送到 viewHeadersocialMedia州。

预期:

登录后,在标签列表中选择一个按钮应该发送tag进入 ViewHeaderSocialMedia 状态/组件。

结果:

登录后,在标签中选择一个按钮并转到 $state dashboard ViewHeaderSocialMedia 的 $states 刷新但 View 模型变量 {{ term }}未使用任一组件中的适当标记进行更新。

enter image description here

设计说明:

我试图通过混合使用状态、组件、同级组件和 View 来解决的问题是,当任何状态发生变化时,应用程序中的每个组件总是刷新/重新启动。 $state.go('dashboard'...

这并不理想,我想要的是确保只有需要刷新的组件才刷新。

IE:当我选择一个 Ticker 或一个 Tag 时,我不希望 Feed 组件每次都刷新。但是,用户应该能够在 Feed 组件中执行操作,它会更新所有其他组件。

这就是我创建 container 的原因状态同时持有 dashboardfeed状态。最初我在 dashboard 中拥有一切状态,随时$state.go('dashboard'发生了 feed组件也会刷新。如果有更好的办法解决这个问题lmk! :)

PS:开始学习使用 ui-router 进行状态管理,以消除对 $rootScope 的依赖。到目前为止,我的真实应用程序要稳定得多,但是有一个令人讨厌的功能,即每个组件都会刷新/重新启动。

enter image description here


在下面的截图中我可以清楚地看到正确的 tag正在传递到正确的 $states,但是 {{ term }}不更新。

enter image description here

enter image description here

代码片段(Plnkr 中的完整代码)

app.container.html(容器状态)

<div>
<dashboard-module></dashboard-module>
<feed-module></feed-module>
<!--<div ui-view="dashboard"></div>-->
<!--<div ui-view="feed"></div>-->
</div>

dashboard.html(仪表板状态)

<div class="jumbotron text-center">
<h1>The Dashboard</h1>
</div>

<div class="row">
<tickers-module></tickers-module>

<!-- Tags component goes here -->
<div ui-view></div>

<view-module></view-module>

<social-module></social-module>
</div>

^ 我使用 <div ui-view> 的原因上面加载标签状态是迄今为止我可以初始化标签模块并显示代码组件中的标签列表的唯一方法。

代码组件 Controller :

tickers.component('tickersModule', {
templateUrl: 'tickers-module-template.html',
controller: function($scope, $state) {
console.log('Tickers component', $state.params);
$scope.tickers = [
{ id: 1, ticker: 'AAPL' },
{ id: 2, ticker: 'GOOG' },
{ id: 3, ticker: 'TWTR' }
];

$state.go('tags', { ticker: $scope.tickers[0] }); // <---

$scope.clickTicker = function(ticker) {
$state.go('tags', { ticker: ticker });
}
}

^ <--- 上面允许标签状态加载标签组件元素并连接标签列表,基于代码的状态

var tags = angular.module('tags', ['ui.router'])
tags.config(function($stateProvider) {

const tags = {
parent: 'container',
name: 'tags',
url: '/tags',
params: {
ticker: {}
},
template: '<tags-module></tags-module>',
controller: function($scope, $state) {
console.log('Tags state', $state.params);
}
}

$stateProvider.state(tags);
})
tags.component('tagsModule', {
templateUrl: 'tags-module-template.html',
controller: function($scope, $state) {
console.log('Tags component', $state.params);
const tags_model = [
{
ticker: 'AAPL',
tags : [{ id: 1, term: 'iPhone 7' }, { id: 2, term: 'iPhone 8' }, { id: 3, term: 'Tim Cook' }]
},
{
ticker: 'GOOG',
tags : [{ id: 4, term: 'Pixel' }, { id: 5, term: 'Pixel XL' }, { id: 6, term: 'Chrome Book' }]
},
{
ticker: 'TWTR',
tags : [{ id: 7, term: 'tweet' }, { id: 8, term: 'retweet' }, { id: 9, term: 'moments' }]
}
];

function matchTags(ticker, model) {
return model.filter(function(obj){
if (obj.ticker === ticker) { return obj; }
});
}

$state.params.ticker = $state.params.ticker || {};
$scope.tags_model = matchTags($state.params.ticker.ticker, tags_model)[0];

$scope.clickTag = function(tag) {
console.log(' Tag clicked', $state);
$state.go('dashboard', { tag: tag });
}
}
});

标签列表中的点击功能:

$scope.clickTag = function(tag) {
console.log(' Tag clicked', $state);
$state.go('dashboard', { tag: tag });
}

社交媒体 Controller :

social.component('socialModule', {
templateUrl: 'social-module-template.html',
controller: function($scope, $state) {
console.log('Social component', $state.params);
$scope.term = $state.params.tag.term;
}
});

viewHeader Controller :

view.component('viewModule', {
templateUrl: 'view-module-template.html',
controller: function($scope, $state) {
console.log('View component', $state.params);
$scope.term = $state.params.tag.term;
}
});

组件的奇怪加倍

刚刚注意到这一点,在点击一个标签并进入 social.component 内部之后。看起来仪表板组件正在重新呈现以代替标签组件一瞬间:

enter image description here


已更新,通过添加 { refresh: true } 解决了这里的问题到 $state.go 标签。但是请注意,这仍然没有解决我最初的任务,即阻止 feed.component 刷新。所以最终会使用服务。

https://plnkr.co/edit/R0iwJznOgEwOL7AtU5wP?p=preview

enter image description here

最佳答案

我已经更新了你的plunker

https://plnkr.co/edit/ywyH7wOmR6loNiAkH9Yb?p=preview

解决方案相当简单。而不是使用 $state 在依赖注入(inject)中使用 $stateParams 这是一个单例,所以如果你像我在更新的 plunker 中那样引用它:

$scope.params = $stateParams

然后是显示值

{{params.ticker.ticker}}

将以两种方式绑定(bind)到 $stateParams 并在您每次更改状态时相应地更新

---编辑---

我通过服务添加了另一个解决方案 https://plnkr.co/edit/oQNAHv7tAS8LR9njOUAX?p=preview

.service('awesomeTag', function($rootScope){
var self = this;
$rootScope.$on('$stateChangeSuccess', function(_event, _toState, toParams){
self.tag = toParams.ticker.ticker
})

})

关于javascript - 如何将 $state 变量传递给其他 2 个同级 $states?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42865321/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com