|
@@ -40,10 +40,21 @@ Component({
|
|
type: Array,
|
|
type: Array,
|
|
value: [],
|
|
value: [],
|
|
observer: function observer() {
|
|
observer: function observer() {
|
|
- if (!this.data.isSwiper) return;
|
|
|
|
- var newVal = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
|
|
|
-
|
|
|
|
- this._videoListChanged(newVal);
|
|
|
|
|
|
+ console.log('数据更新111111', arguments)
|
|
|
|
+ let newValue = arguments[0];
|
|
|
|
+ let oldValue = arguments[1];
|
|
|
|
+ if (newValue && oldValue && (this.data.activeIndex || this.data.activeIndex === 0)) {
|
|
|
|
+ let newVideoShow = newValue[this.data.activeIndex].videoShow;
|
|
|
|
+ let oldVideoShow = oldValue[this.data.activeIndex].videoShow;
|
|
|
|
+ if (newVideoShow !== oldVideoShow && oldVideoShow) {
|
|
|
|
+ console.log('把值设置为true')
|
|
|
|
+ newValue[this.data.activeIndex].videoShow = true;
|
|
|
|
+ this.setData({
|
|
|
|
+ })
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ let newVal = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
|
|
|
+ this.updateSonList(newVal);
|
|
}
|
|
}
|
|
},
|
|
},
|
|
nextMargin: {
|
|
nextMargin: {
|
|
@@ -53,6 +64,8 @@ Component({
|
|
}
|
|
}
|
|
},
|
|
},
|
|
data: {
|
|
data: {
|
|
|
|
+ sonVideoList: [], // 子组件里的视频组件
|
|
|
|
+ activeType: '',
|
|
nextQueue: [],
|
|
nextQueue: [],
|
|
prevQueue: [],
|
|
prevQueue: [],
|
|
curQueue: [],
|
|
curQueue: [],
|
|
@@ -73,6 +86,13 @@ Component({
|
|
this.data._videoContexts = [wx.createVideoContext('video_0', this), wx.createVideoContext('video_1', this), wx.createVideoContext('video_2', this)];
|
|
this.data._videoContexts = [wx.createVideoContext('video_0', this), wx.createVideoContext('video_1', this), wx.createVideoContext('video_2', this)];
|
|
}
|
|
}
|
|
},
|
|
},
|
|
|
|
+ /* observers: {
|
|
|
|
+ '**': function() {
|
|
|
|
+ // 每次 setData 都触发
|
|
|
|
+ console.log('数据更新333333',this.data)
|
|
|
|
+
|
|
|
|
+ },
|
|
|
|
+ }, */
|
|
methods: {
|
|
methods: {
|
|
_videoListChanged: function _videoListChanged(newVal) {
|
|
_videoListChanged: function _videoListChanged(newVal) {
|
|
var _this = this;
|
|
var _this = this;
|
|
@@ -91,6 +111,12 @@ Component({
|
|
});
|
|
});
|
|
}
|
|
}
|
|
},
|
|
},
|
|
|
|
+ updateSonList: function updateSonList(newVal) {
|
|
|
|
+ this.setData({
|
|
|
|
+ sonVideoList: newVal,
|
|
|
|
+ activeIndex: ''
|
|
|
|
+ })
|
|
|
|
+ },
|
|
animationfinish: function animationfinish(e) {
|
|
animationfinish: function animationfinish(e) {
|
|
var _data = this.data,
|
|
var _data = this.data,
|
|
_last = _data._last,
|
|
_last = _data._last,
|
|
@@ -223,15 +249,19 @@ Component({
|
|
},
|
|
},
|
|
openComment: function openComment(e) {
|
|
openComment: function openComment(e) {
|
|
console.log(e)
|
|
console.log(e)
|
|
|
|
+ let index = e.currentTarget.dataset.index;
|
|
|
|
+ this.setData({
|
|
|
|
+ activeIndex:index
|
|
|
|
+ })
|
|
this.trigger(e, 'openComment')
|
|
this.trigger(e, 'openComment')
|
|
},
|
|
},
|
|
// 展示视频
|
|
// 展示视频
|
|
showVideo: function showVideo(e) {
|
|
showVideo: function showVideo(e) {
|
|
let index = e.target.dataset.index ? e.target.dataset.index : e.currentTarget.dataset.index;
|
|
let index = e.target.dataset.index ? e.target.dataset.index : e.currentTarget.dataset.index;
|
|
console.log('showVideo')
|
|
console.log('showVideo')
|
|
- const str = `videoList[${index}].videoShow`;
|
|
|
|
|
|
+ const str = `sonVideoList[${index}].videoShow`;
|
|
if (this.data.lastIndex || this.data.lastIndex === 0) {
|
|
if (this.data.lastIndex || this.data.lastIndex === 0) {
|
|
- const lastStr = `videoList[${this.data.lastIndex}].videoShow`;
|
|
|
|
|
|
+ const lastStr = `sonVideoList[${this.data.lastIndex}].videoShow`;
|
|
this.setData({
|
|
this.setData({
|
|
lastIndex: index,
|
|
lastIndex: index,
|
|
[lastStr]: false,
|
|
[lastStr]: false,
|
|
@@ -285,6 +315,9 @@ Component({
|
|
favoritesType: e.target.dataset.type ? e.target.dataset.type : e.currentTarget.dataset.type
|
|
favoritesType: e.target.dataset.type ? e.target.dataset.type : e.currentTarget.dataset.type
|
|
}
|
|
}
|
|
const index = e.target.dataset.index ? e.target.dataset.index : e.currentTarget.dataset.index;
|
|
const index = e.target.dataset.index ? e.target.dataset.index : e.currentTarget.dataset.index;
|
|
|
|
+ this.setData({
|
|
|
|
+ activeIndex:index
|
|
|
|
+ })
|
|
console.log('视频index', index);
|
|
console.log('视频index', index);
|
|
if (this.data.curQueue.length <= 0) {
|
|
if (this.data.curQueue.length <= 0) {
|
|
let str = `videoList[${index}].isFavorite`
|
|
let str = `videoList[${index}].isFavorite`
|
|
@@ -335,7 +368,9 @@ Component({
|
|
const id = e.target.dataset.id ? e.target.dataset.id : e.currentTarget.dataset.id;
|
|
const id = e.target.dataset.id ? e.target.dataset.id : e.currentTarget.dataset.id;
|
|
const index = e.target.dataset.index ? e.target.dataset.index : e.currentTarget.dataset.index;
|
|
const index = e.target.dataset.index ? e.target.dataset.index : e.currentTarget.dataset.index;
|
|
this.setData({
|
|
this.setData({
|
|
- addComeOut: index
|
|
|
|
|
|
+ addComeOut: index,
|
|
|
|
+ activeIndex: index,
|
|
|
|
+ activeType: 'like'
|
|
})
|
|
})
|
|
setTimeout(() => {
|
|
setTimeout(() => {
|
|
if (this.data.addComeOut) {
|
|
if (this.data.addComeOut) {
|
|
@@ -373,10 +408,10 @@ Component({
|
|
},
|
|
},
|
|
addShareAmount: function (e) {
|
|
addShareAmount: function (e) {
|
|
console.log('+++++1', e.detail.index);
|
|
console.log('+++++1', e.detail.index);
|
|
-
|
|
|
|
|
|
+
|
|
this.triggerEvent('addShareAmount', {
|
|
this.triggerEvent('addShareAmount', {
|
|
- index:e.detail.index
|
|
|
|
- })
|
|
|
|
|
|
+ index: e.detail.index
|
|
|
|
+ })
|
|
},
|
|
},
|
|
// 下载视频
|
|
// 下载视频
|
|
download: function (e) {
|
|
download: function (e) {
|
|
@@ -516,7 +551,7 @@ Component({
|
|
var activeIndex = e.target.dataset.index ? e.target.dataset.index : e.currentTarget.dataset.index;
|
|
var activeIndex = e.target.dataset.index ? e.target.dataset.index : e.currentTarget.dataset.index;
|
|
this.triggerEvent(type, {
|
|
this.triggerEvent(type, {
|
|
activeId: activeId,
|
|
activeId: activeId,
|
|
- activeIndex:activeIndex
|
|
|
|
|
|
+ activeIndex: activeIndex
|
|
}, {
|
|
}, {
|
|
bubbles: false
|
|
bubbles: false
|
|
});
|
|
});
|