DevOps git сохраняет проверенные данные при переключении ветки в VS 2022

Происходит следующее: я работаю над веткой и проверяю изменения, а затем переключаюсь на мастер. На вкладке Git показаны все файлы, которые я только что зарегистрировал в другой ветке...

Если я вытащу мастер-файл, он очистит его, или я могу удалить изменения, чтобы удалить их вручную. Но мне нужно, чтобы удалить отмеченные изменения, поэтому я перехожу на мастер, как и должно быть.

Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
0
0
71
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Я работаю над веткой и проверяю изменения, а затем переключаюсь на мастер. На вкладке Git показаны все файлы, которые я только что зарегистрировал в другой ветке...

Согласно моему тесту, когда я добавляю изменения в другую ветку, не фиксируя их, я могу воспроизвести аналогичную проблему в Visual Studio.

Причина проблемы в том, что созданные/измененные файлы не помещаются ни в какие ветки, пока вы их не добавите и не зафиксируете. Поэтому независимо от того, в какой ветке вы находитесь, файл все равно будет там локально.

Чтобы решить эту проблему, вы можете переключиться обратно на другую ветку и зафиксировать изменения, тогда они больше не появятся в главной ветке.

Например:

Результат:

Да, я уже зафиксировал код, затем он возвращается, когда я переключаю ветки.... после этого, если я перетаскиваю ветку, в которую я перехожу, все эти изменения исчезают, как будто он не обновляет локальные данные, когда я переключаю ветку

CoolDaemonX 17.05.2024 03:59

@CoolDaemonX, можете ли вы поделиться снимками экрана с описанием этапов решения проблемы? Это поможет решить проблему

Kevin Lu-MSFT 17.05.2024 05:11

Похоже, сейчас он этого не делает... если это произойдет снова, я сделаю скриншоты.

CoolDaemonX 17.05.2024 20:51

@CoolDaemonX Насколько я знаю, если мы зафиксируем изменения в целевой ветке, файлы не будут отображаться при переключении веток. Ситуация, с которой вы столкнулись ранее, также может быть вызвана кешем VS. Это можно решить, перезапустив VS.

Kevin Lu-MSFT 20.05.2024 08:11

Похоже, возникла проблема с кэшем. Я больше не вижу панели проблем, созданной нечетной корзины или папки vs, о которой еще не сообщается как проигнорированной.

CoolDaemonX 21.05.2024 03:34

@CoolDaemonX, не могли бы вы поделиться снимком экрана с новой проблемой? Я постараюсь помочь.

Kevin Lu-MSFT 21.05.2024 03:54

@CoolDaemonX Если вам нужно игнорировать папку vs при внесении изменений в git, вы можете добавить файл .gitignore в свой репозиторий, чтобы игнорировать папку vs. Обратитесь к этому документу: Learn.microsoft.com/en-us/azure/devops/repos/git/…

Kevin Lu-MSFT 21.05.2024 09:48

Да, я решил эту проблему с изменением файлов, однако я замечаю, что если я игнорирую файлы в папках .vs bin или obj и фиксирую игнорирование, главная ветвь не видит игнорирования до тех пор, пока ветка не будет отправлена ​​в главную... это не такая уж проблема.

CoolDaemonX 24.05.2024 23:07

@CoolDaemonX Вам нужно один раз добавить файл ignore в ветку, а затем извлечь ветку, чтобы внести изменения. Затем вы увидите, что папки .vs и bin будут игнорироваться.

Kevin Lu-MSFT 27.05.2024 09:04

Другие вопросы по теме