Controls Webpage with Knockout: Visible changes not saved

前端 未结 2 902
无人及你
无人及你 2021-01-18 01:03

Trying to edit a website with Excel VBA. The edits appear to work, but when I use the save button, nothing is saved. Why isn\'t updated data, which is visible on the screen,

相关标签:
2条回答
  • 2021-01-18 01:09

    As the regarding web site can not be shared, I can come up with a just set of hints to try out:

    If the web site would implement a simple (pure) HTML form to send the POST request, your solution would be fine. But looking at the HTML you shared

    <label data-bind="text: ProjectFile().ProposalDpLabel()"></label>
    

    the data-bind is already suggesting that the data is getting collected/sent by a library. (E.g. Knockout is using that attribute). This library might now collect the data somewhere, and it might get triggered by a "click" or a "key" event in JavaScript. The collected information can then be stored in a hidden DOM element as suggested by GCSDC or directly in a JavaScript variable.

    What I would suggest now is to find out which JavaScript framework is used on this page by inspecting the HTML source. At some point there should be a

    <script src="<fancy js framework>.js"></script>
    

    tag in the HTML, which should give you the name of the framework. (There can actually be multiple tags of this kind, including custom JavaScript files. These tags do not have to be at the beginning of the HTML document, and can be scattered all over it, so you might have to search for script in the HTML document. One of them should be the main framework, which is sending the request. If you are not sure which one it would be, you have to google all of them and find out.)

    Then, research how the the POST (maybe Ajax) request is sent in the JavaScript code on this page, with help from the documentation of the Framework. And then, send the request by executing custom JavaScript from VBA on this page; how this could be done is shown in this post.

    Alternatively, you could try to trigger a click (or key) event on the form inputs to make the framework believe you actually typed it in; how this could be done is shown in this post, but this might not work in all cases.

    0 讨论(0)
  • 2021-01-18 01:17

    Per your comment that:

    1. Pause my code, manually change a checkbox and run the code to save (does save the manual change, but not the coded ones

    It seems that the problem is with the code setting form controls and not with the code clicking the save button.

    This seems to be a problem not related to VBA but with the behaviour of knockout - see this SO post. The pertinent comment is:

    Your problem is that ko subscribes on the click event inside the checked binding:

    The questioner in that post is having a similar problem to you - they are trying to check a checkbox (to change the view) but it is not updating either the viewmodel, or the underlying model itself. Knockout is a MVVM framework.

    The give-away in your question is that your manual changes commit because you perform a click-and-change when performing the action via point-and-click in the browser, but your programmatic method only does the change to the form control, but not the click first.

    So, how to solve this via VBA automation through IE?

    Based on the solution in the post I referenced above, plus the method here I will hazard the code below as a possible solution, but please note it is untested ...

    Basically you need to 'click' on the form element you want to change - and then update the control value. Hopefully the 'clicking' bit will mean that the knockout viewmodel updates per the 'change', and from there, the model data will be written to the database (or whatever):

    Your checkbox example:

    If InStr(ExtractedName, "NewPermit") > 0 Then
    // hopefully this will get knockout to apply the required binding before your change the value
    objElement.Click
    objElement.Checked = True
    

    Your dropdown example:

    Set DropDown = objHTML.getElementById("ProjectFile-AccreditedCertifierId")
    // hopefully this will get knockout to apply the required binding before your change the value
    Dropdown.Click
    DropDown.selectedIndex = 1
    

    Hope that helps - quite the 3-pipe problem! Good luck.

    0 讨论(0)
提交回复
热议问题