官术网_书友最值得收藏!

Debugging data bound values

So far, we have seen that we can utilize a number of sources of information to help with tracking down the causes of our problems. However, what about actual debugging? In other GUI languages, we can add breakpoints at various locations in our code and watch our values changing as we step through our code. While we can also do this with WPF applications, it is not always so obvious where to put our breakpoints to ensure that program execution will hit them.

If you remember from the previous chapter, the CommandManager.RequerySuggested event is raised when CommandManager detects a change in the UI that could reflect on whether a command could execute or not. Well, it turns out that two of the conditions that the CommandManager looks out for is when the application window is either activated or deactivated and we can take advantage of this to help us when debugging. Note that the application window is deactivated when the user moves focus from it and is reactivated when the user returns focus to it.

Therefore, while running the application side by side with Visual Studio, we can put a breakpoint in any method that is being used as a canExecute handler for our ActionCommand class, thereby removing focus from the application. Now, when we click back on the WPF application, the focus will be returned to it.

This will cause the CommandManager.RequerySuggested event to be raised and as a result, the canExecute handler will be called and our breakpoint will be hit. This basically means that we are able to get the program execution into our View Models to debug parameter values any and every time that we need to. Let's see what else we can do to help fix our data binding errors.

主站蜘蛛池模板: 浮梁县| 开封市| 汉阴县| 鸡西市| 玉屏| 新郑市| 珲春市| 虹口区| 达日县| 喀喇| 白朗县| 翁源县| 北票市| 涞源县| 紫阳县| 偃师市| 炉霍县| 延津县| 蓬溪县| 吴旗县| 金阳县| 岑溪市| 彩票| 二连浩特市| 江达县| 蓝田县| 和顺县| 五大连池市| 宁陵县| 道孚县| 仪陇县| 安丘市| 东至县| 文成县| 桦南县| 隆子县| 贺兰县| 普安县| 会泽县| 揭阳市| 蚌埠市|